Ability to sort cur.playlist by long tap on it
[someplayer] / src / libraryform.h
index 5b61062..2d7cba6 100644 (file)
@@ -26,6 +26,9 @@
 #include <QStandardItemModel>
 #include <QStandardItem>
 #include <QModelIndex>
+#include <QItemSelectionModel>
+#include <QItemSelection>
+#include <QPushButton>
 #include "playlist.h"
 #include "toolswidget.h"
 
@@ -37,7 +40,7 @@ using SomePlayer::DataObjects::Library;
 using SomePlayer::DataObjects::Track;
 using SomePlayer::DataObjects::Playlist;
 
-enum LibraryFormListState {STATE_NONE, STATE_ARTIST, STATE_ALBUM, STATE_TRACK, STATE_PLAYLIST, STATE_PLAYLIST_TRACK, STATE_DYNAMIC};
+enum LibraryFormListState {STATE_NONE, STATE_ARTIST, STATE_ALBUM, STATE_TRACK, STATE_PLAYLIST, STATE_PLAYLIST_TRACK, STATE_DYNAMIC, STATE_SEARCH};
 
 class LibraryForm : public QWidget
 {
@@ -45,12 +48,10 @@ class LibraryForm : public QWidget
 
 public:
        explicit LibraryForm(Library *lib, QWidget *parent = 0);
-    ~LibraryForm();
+       ~LibraryForm();
 signals:
-       void player(bool);
-       void busy(QString);
-       void done();
-       void fullscreen(bool);
+       void refreshPlayer();
+       void addAndPlay(Track);
 public slots:
        void search(QString);
        void nextItem();
@@ -61,8 +62,8 @@ public slots:
        void portraitMode();
        void updateIcons();
        void checkGradient();
+       void updateTranslations();
 private slots:
-       void _player();
        void _view_button();
        void _dynamic_button();
        void _playlists_button();
@@ -72,25 +73,34 @@ private slots:
        void _back_button();
        void _use_button();
        void _process_list_click(QModelIndex);
+       void _process_dblclick(QModelIndex);
+       void _process_selection(QItemSelection, QItemSelection);
        void _more_button();
+       void _search_button(bool);
+       void _search_in_library(QString);
 
 private:
        Ui::LibraryForm *ui;
        Library *_lib;
        QStandardItemModel *_model;
        LibraryFormListState _state;
+       bool _is_dynamic; // workaround
+        bool _is_favorites; // workaround
        QString _current_artist;
        QString _current_album;
        Playlist _current_playlist;
        QList<Track> _current_tracks;
        QString _search_pattern;
        int _search_current_id;
-       bool _current_playlist_changed;
        ToolsWidget *_tools_widget;
+       QPushButton *_search_in_library_button;
        bool landscape;
        QString _icons_theme;
        QString _top_gradient;
        QString _bottom_gradient;
+       int _artist_row_for_scroll_to;
+       int _album_row_for_scroll_to;
+       int _playlist_row_for_scroll_to;
 
        void _add_artist(Playlist *cur, QString artist);
        void _add_album(Playlist *cur, QString artist, QString album);