X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=modules%2Fgui%2Fqt4%2Fcomponents%2Fplaylist%2Fplaylist_model.hpp;h=cb5e68c3e04766c9ee682acc8f9eeaa6b6c192c5;hb=790811343ae90c501aabd1a40ec375659fd415f2;hp=1cb9695a9b957ee39b69d1dadc2ae3ed02e4fa8f;hpb=aa774ef953dbb63c74877daaccb3fb1a3e36221f;p=vlc diff --git a/modules/gui/qt4/components/playlist/playlist_model.hpp b/modules/gui/qt4/components/playlist/playlist_model.hpp index 1cb9695a9b..cb5e68c3e0 100644 --- a/modules/gui/qt4/components/playlist/playlist_model.hpp +++ b/modules/gui/qt4/components/playlist/playlist_model.hpp @@ -45,40 +45,8 @@ #include class QSignalMapper; - class PLItem; -#define DEPTH_PL -1 -#define DEPTH_SEL 1 - -enum { - ItemUpdate_Type = QEvent::User + PLEventType + 2, - ItemDelete_Type = QEvent::User + PLEventType + 3, - ItemAppend_Type = QEvent::User + PLEventType + 4, -}; - -class PLEvent : public QEvent -{ -public: - PLEvent( int type, int id ) : QEvent( (QEvent::Type)(type) ) - { - i_id = id; - add.i_node = -1; - add.i_item = -1; - }; - - PLEvent( const playlist_add_t *a ) : QEvent( (QEvent::Type)(ItemAppend_Type) ) - { - add = *a; - }; - - virtual ~PLEvent() { }; - - int i_id; - playlist_add_t add; -}; - - class PLModel : public QAbstractItemModel { Q_OBJECT @@ -86,8 +54,12 @@ class PLModel : public QAbstractItemModel friend class PLItem; public: + enum { + IsCurrentRole = Qt::UserRole + }; + PLModel( playlist_t *, intf_thread_t *, - playlist_item_t *, int, QObject *parent = 0 ); + playlist_item_t *, QObject *parent = 0 ); ~PLModel(); /*** QModel subclassing ***/ @@ -113,14 +85,14 @@ public: /* Lookups */ QStringList selectedURIs(); - bool hasRandom(); bool hasLoop(); bool hasRepeat(); QModelIndex index( PLItem *, int c ) const; - QModelIndex currentIndex( ) { return index( currentItem, 0 ); }; + QModelIndex index( int i_id, int c ); + QModelIndex currentIndex(); bool isCurrent( const QModelIndex &index ) const; int itemId( const QModelIndex &index ) const; /* Actions */ - void popup( QModelIndex & index, QPoint &point, QModelIndexList list ); + void popup( const QModelIndex & index, const QPoint &point, const QModelIndexList &list ); void doDelete( QModelIndexList selected ); void search( const QString& search_text ); void sort( int column, Qt::SortOrder order ); @@ -128,11 +100,17 @@ public: void removeItem( int ); void rebuild(); void rebuild( playlist_item_t *, bool b_first = false ); + inline PLItem *getItem( QModelIndex index ) const + { + if( index.isValid() ) + return static_cast( index.internalPointer() ); + else return rootItem; + } + private: /* General */ PLItem *rootItem; - PLItem *currentItem; playlist_t *p_playlist; intf_thread_t *p_intf; @@ -140,23 +118,16 @@ private: static QIcon icons[ITEM_TYPE_NUMBER]; - /* Callbacks related */ - void addCallbacks(); - void delCallbacks(); - void customEvent( QEvent * ); - void processItemRemoval( int i_id ); - void processItemAppend( const playlist_add_t *p_add ); - /* Actions */ void recurseDelete( QList children, QModelIndexList *fullList ); void doDeleteItem( PLItem *item, QModelIndexList *fullList ); - void updateTreeItem( PLItem *, bool, bool force = false ); + void updateTreeItem( PLItem * ); + void removeItem ( PLItem * ); void takeItem( PLItem * ); //will not delete item void insertChildren( PLItem *node, QList& items, int i_pos ); void dropAppendCopy( QByteArray& data, PLItem *target ); void dropMove( QByteArray& data, PLItem *target, int new_pos ); /* The following actions will not signal the view! */ - void removeItem ( PLItem * ); void updateChildren( PLItem * ); void updateChildren( playlist_item_t *, PLItem * ); @@ -168,24 +139,22 @@ private: PLItem *findById( PLItem *, int ); PLItem *findByInput( PLItem *, int ); PLItem *findInner( PLItem *, int , bool ); - static inline PLItem *getItem( QModelIndex index ); + int columnFromMeta( int meta_column ) const; int columnToMeta( int column ) const; + bool canEdit() const; PLItem *p_cached_item; PLItem *p_cached_item_bi; int i_cached_id; int i_cached_input_id; signals: - void shouldRemove( int ); void currentChanged( const QModelIndex& ); + void rootChanged(); public slots: void activateItem( const QModelIndex &index ); void activateItem( playlist_item_t *p_item ); - void setRandom( bool ); - void setLoop( bool ); - void setRepeat( bool ); private slots: void popupPlay(); @@ -199,6 +168,8 @@ private slots: void popupSortDesc(); void processInputItemUpdate( input_item_t *); void processInputItemUpdate( input_thread_t* p_input ); + void processItemRemoval( int i_id ); + void processItemAppend( int item, int parent ); }; #endif