Fixed uninitialized state in library form
[someplayer] / src / libraryform.cpp
index 975e47b..2b8c092 100644 (file)
@@ -55,6 +55,37 @@ inline void __fill_model(QStandardItemModel *model, QList<QString> data, QString
        }
 }
 
+inline void __fill_model_album(QStandardItemModel *model, QMap<QString, int> data, QString icons_theme) {
+       model->clear();
+       int count = data.count();
+       model->setRowCount(count);
+       int i = 0;
+       Config config;
+       if (config.getValue("ui/albumsorting").toString() == "date") {
+               QMap<int, QList<QString> > years;
+               foreach (QString name, data.keys()) {
+                       years[data[name]].append(name);
+               }
+               QList<int> keys = years.keys();
+               qSort(keys);
+
+               foreach (int year, keys) {
+                       foreach (QString name, years[year]) {
+                               model->setItem(i, 0, new QStandardItem(QIcon(":/icons/"+icons_theme+"/deselect_all.png"), ""));
+                               model->setItem(i, 1, new QStandardItem(QString("[%1] %2").arg(year).arg(name)));
+                               i++;
+                       }
+               }
+       } else {
+               QList<QString> names = data.keys();
+               foreach (QString name, names) {
+                       model->setItem(i, 0, new QStandardItem(QIcon(":/icons/"+icons_theme+"/deselect_all.png"), ""));
+                       model->setItem(i, 1, new QStandardItem(QString("[%1] %2").arg(data[name]).arg(name)));
+                       i++;
+               }
+       }
+}
+
 inline void __fill_model_tracks (QStandardItemModel *model, QList<Track> tracks, QString icons_theme) {
        int count = tracks.count();
        model->setRowCount(count);
@@ -83,6 +114,11 @@ LibraryForm::LibraryForm(Library *lib, QWidget *parent) :
        _model->setColumnCount(2);
        _state = STATE_NONE;
        _tools_widget = new ToolsWidget(this);
+       QPushButton *search_in_library = new QPushButton(QIcon(":/icons/"+_icons_theme+"/search.png"), "", _tools_widget);
+       search_in_library->setFlat(true);
+       search_in_library->setCheckable(true);
+       _tools_widget->layout()->addItem(new QSpacerItem(20, 20));
+       _tools_widget->layout()->addWidget(search_in_library);
        ui->setupUi(this);
        ui->listView->setModel(_model);
        ui->listView->setColumnWidth(0, 70);
@@ -106,10 +142,12 @@ LibraryForm::LibraryForm(Library *lib, QWidget *parent) :
        connect(_tools_widget, SIGNAL(prevSearch()), this, SLOT(prevItem()));
        connect(_tools_widget, SIGNAL(toggleFullscreen(bool)), this, SIGNAL(fullscreen(bool)));
        connect(ui->moreButton, SIGNAL(clicked()), this, SLOT(_more_button()));
+       connect(search_in_library, SIGNAL(toggled(bool)), this, SLOT(_search_button(bool)));
        _view_button();
        _current_playlist_changed = true;
        _top_gradient = ui->topWidget->styleSheet();
        _bottom_gradient = ui->bottomWidget->styleSheet();
+       _is_dynamic = false;
 }
 
 LibraryForm::~LibraryForm()
@@ -168,9 +206,10 @@ void LibraryForm::_process_list_click(QModelIndex index) {
        }
        if (_state == STATE_NONE) return;
        QString data = index.data().toString();
+       QRegExp regexp("\\[\\d+\\]\\ (.*)");
        switch (_state) {
        case STATE_ARTIST:
-               __fill_model(_model, _lib->getAlbumsForArtist(data), _icons_theme);
+               __fill_model_album(_model, _lib->getAlbumsForArtist(data), _icons_theme);
                ui->listView->setColumnWidth(0, 70);
                ui->listView->scrollToTop();
                _current_artist = data;
@@ -179,14 +218,16 @@ void LibraryForm::_process_list_click(QModelIndex index) {
                ui->listLabel->setText(QString("Albums by \"%1\"").arg(_current_artist));
                break;
        case STATE_ALBUM:
-               _current_album = data;
-               _current_tracks = _lib->getTracksForAlbum(data, _current_artist);
-               __fill_model_tracks(_model, _current_tracks, _icons_theme);
-               ui->listView->setColumnWidth(0, 70);
-               ui->listView->scrollToTop();
-               _state = STATE_TRACK;
-               ui->backButton->setEnabled(true);
-               ui->listLabel->setText(QString("Tracks from \"%1\" by \"%2\"").arg(_current_album).arg(_current_artist));
+               if (regexp.indexIn(data) != -1) {
+                       _current_album = regexp.cap(1).trimmed();
+                       _current_tracks = _lib->getTracksForAlbum(_current_album, _current_artist);
+                       __fill_model_tracks(_model, _current_tracks, _icons_theme);
+                       ui->listView->setColumnWidth(0, 70);
+                       ui->listView->scrollToTop();
+                       _state = STATE_TRACK;
+                       ui->backButton->setEnabled(true);
+                       ui->listLabel->setText(QString("Tracks from \"%1\" by \"%2\"").arg(_current_album).arg(_current_artist));
+               }
                break;
        case STATE_PLAYLIST:
                {
@@ -246,6 +287,7 @@ void LibraryForm::_add_button() {
        ui->listView->selectionModel()->clearSelection();
        emit busy(QString("<H1>Adding... Please wait</H1>"));
        Playlist cur = _lib->getCurrentPlaylist();
+       QRegExp regexp("\\[\\d+\\]\\ (.*)");
        switch (_state) {
        case STATE_ARTIST:
                foreach (QModelIndex id, selected) {
@@ -256,7 +298,9 @@ void LibraryForm::_add_button() {
                break;
        case STATE_ALBUM:
                foreach (QModelIndex id, selected) {
-                       _add_album(&cur, _current_artist, id.data().toString());
+                       if (regexp.indexIn(id.data().toString()) != -1) {
+                               _add_album(&cur, _current_artist, regexp.cap(1).trimmed());
+                       }
                }
                _lib->saveCurrentPlaylist(cur);
                _current_playlist_changed = true;
@@ -282,6 +326,13 @@ void LibraryForm::_add_button() {
                _lib->saveCurrentPlaylist(cur);
                _current_playlist_changed = true;
                break;
+       case STATE_SEARCH:
+               foreach (QModelIndex id, selected) {
+                       _add_track(&cur, _current_tracks.at(id.row()));
+               }
+               _lib->saveCurrentPlaylist(cur);
+               _current_playlist_changed = true;
+               break;
        default:
                emit done();
                return;
@@ -291,8 +342,8 @@ void LibraryForm::_add_button() {
 
 
 void LibraryForm::_add_artist(Playlist *cur, QString artist) {
-       QList<QString> albums = _lib->getAlbumsForArtist(artist);
-       foreach(QString album, albums) {
+       QMap<QString, int> albums = _lib->getAlbumsForArtist(artist);
+       foreach(QString album, albums.keys()) {
                _add_album(cur, artist, album);
        }
 }
@@ -323,7 +374,7 @@ void LibraryForm::_back_button() {
                ui->listView->scrollToTop();
                break;
        case STATE_TRACK:
-               __fill_model(_model, _lib->getAlbumsForArtist(_current_artist), _icons_theme);
+               __fill_model_album(_model, _lib->getAlbumsForArtist(_current_artist), _icons_theme);
                ui->listView->setColumnWidth(0, 70);
                ui->listView->scrollToTop();
                _state = STATE_ALBUM;
@@ -363,7 +414,8 @@ void LibraryForm::_delete_button() {
                ui->listView->selectionModel()->clearSelection();
                QQueue<int> to_delete;
                foreach (QModelIndex id, selected) {
-                       to_delete.append(id.row());
+                       if (!to_delete.contains(id.row()))
+                               to_delete.append(id.row());
                }
                qSort(to_delete);
                int count = to_delete.count();
@@ -379,12 +431,13 @@ void LibraryForm::_delete_button() {
                QModelIndexList selected = ui->listView->selectionModel()->selectedIndexes();
                QQueue<int> to_delete;
                foreach (QModelIndex id, selected) {
-                       to_delete.append(id.row());
+                       if (!to_delete.contains(id.row()))
+                               to_delete.append(id.row());
                }
                qSort(to_delete);
                int count = to_delete.count();
                for (int i = count-1; i >= 0; i--) {
-                       QString name = _model->item(to_delete.at(i))->text();
+                       QString name = _model->item(to_delete.at(i), 1)->text();
                        if (name != _CURRENT_PLAYLIST_SUBST_) {
                                _lib->removePlaylist(name);
                                _model->removeRow(to_delete.at(i));
@@ -413,7 +466,6 @@ void LibraryForm::search(QString pattern) {
 }
 
 void LibraryForm::nextItem() {
-       qWarning() << "searching" << _search_pattern;
        QString data = _model->index(_search_current_id, 0).data().toString();
        for (int i = _search_current_id+1; i < _model->rowCount(); i++) {
                data = _model->index(i, 1).data().toString();
@@ -454,7 +506,7 @@ void LibraryForm::refresh() {
                _view_button();
                break;
        case STATE_ALBUM:
-               __fill_model(_model, _lib->getAlbumsForArtist(_current_artist), _icons_theme);
+               __fill_model_album(_model, _lib->getAlbumsForArtist(_current_artist), _icons_theme);
                ui->listView->setColumnWidth(0, 70);
                break;
        case STATE_PLAYLIST:
@@ -653,8 +705,7 @@ void LibraryForm::_process_selection(QItemSelection selected, QItemSelection des
 void LibraryForm::_process_dblclick(QModelIndex id) {
        if (id.column() == 0)
                return;
-       if (_state == STATE_TRACK || _state == STATE_PLAYLIST_TRACK) {
-               qWarning() << "double clicked";
+       if (_state == STATE_TRACK || _state == STATE_PLAYLIST_TRACK || _state == STATE_SEARCH) {
                Playlist cur = _lib->getCurrentPlaylist();
                Track track = _current_tracks.at(id.row());
                cur.addTrack(track);
@@ -665,3 +716,39 @@ void LibraryForm::_process_dblclick(QModelIndex id) {
        }
 }
 
+void LibraryForm::_search_button(bool state) {
+       ui->moreButton->setEnabled(!state);
+       _tools_widget->toggleArrows(!state);
+       ui->backButton->setEnabled(!state);
+       _tools_widget->setFocus();
+       _tools_widget->reset();
+       if (state) {
+               ui->listLabel->setText("Search in library");
+               ui->deleteButton->setIcon(QIcon());
+               ui->deleteButton->setEnabled(false);
+               ui->useButton->setIcon(QIcon());
+               ui->useButton->setEnabled(false);
+               ui->addButton->setIcon(QIcon(":/icons/"+_icons_theme+"/add.png"));
+               ui->addButton->setEnabled(true);
+               disconnect(_tools_widget, SIGNAL(search(QString)), this, SLOT(search(QString)));
+               connect(_tools_widget, SIGNAL(search(QString)), this, SLOT(_search_in_library(QString)));
+               _model->clear();
+               _state = STATE_SEARCH;
+       } else {
+               _view_button();
+               connect(_tools_widget, SIGNAL(search(QString)), this, SLOT(search(QString)));
+               disconnect(_tools_widget, SIGNAL(search(QString)), this, SLOT(_search_in_library(QString)));
+       }
+}
+
+void LibraryForm::_search_in_library(QString pattern) {
+       pattern = pattern.trimmed();
+       if (pattern.isEmpty()) {
+               _model->clear();
+               return;
+       }
+       _current_tracks = _lib->search(pattern);
+       __fill_model_tracks(_model, _current_tracks, _icons_theme);
+       ui->listView->setColumnWidth(0, 70);
+       ui->listView->scrollToTop();
+}