diff --git a/src/internet/groovesharkservice.cpp b/src/internet/groovesharkservice.cpp
index fd9dc7d9f..522265e1f 100644
--- a/src/internet/groovesharkservice.cpp
+++ b/src/internet/groovesharkservice.cpp
@@ -102,6 +102,7 @@ GroovesharkService::GroovesharkService(Application* app, InternetModel *parent)
remove_from_playlist_(NULL),
remove_from_favorites_(NULL),
get_url_to_share_song_(NULL),
+ get_url_to_share_playlist_(NULL),
search_delay_(new QTimer(this)),
last_search_reply_(NULL),
api_key_(QByteArray::fromBase64(kApiSecret)),
@@ -442,7 +443,8 @@ void GroovesharkService::ShowContextMenu(const QPoint& global_pos) {
bool display_delete_playlist_action = false,
display_remove_from_playlist_action = false,
display_remove_from_favorites_action = false,
- display_share_song_url = false;
+ display_share_song_url = false,
+ display_share_playlist_url = false;
QModelIndex index(model()->current_index());
@@ -466,12 +468,26 @@ void GroovesharkService::ShowContextMenu(const QPoint& global_pos) {
remove_from_playlist_->setVisible(display_remove_from_playlist_action);
remove_from_favorites_->setVisible(display_remove_from_favorites_action);
+ // Check if we can display actions to get URL for sharing songs/playlists:
+ // - share song
if (index.data(InternetModel::Role_Type).toInt() == Type_Track) {
display_share_song_url = true;
current_song_id_ = ExtractSongId(index.data(InternetModel::Role_Url).toUrl());
}
get_url_to_share_song_->setVisible(display_share_song_url);
+ // - share playlist
+ if (index.data(InternetModel::Role_Type).toInt() == InternetModel::Type_UserPlaylist
+ && index.data(Role_UserPlaylistId).isValid()) {
+ display_share_playlist_url = true;
+ current_playlist_id_ = index.data(Role_UserPlaylistId).toInt();
+ } else if (parent_type == InternetModel::Type_UserPlaylist
+ && index.parent().data(Role_UserPlaylistId).isValid()) {
+ display_share_playlist_url = true;
+ current_playlist_id_ = index.parent().data(Role_UserPlaylistId).toInt();
+ }
+ get_url_to_share_playlist_->setVisible(display_share_playlist_url);
+
context_menu_->popup(global_pos);
}
@@ -501,6 +517,9 @@ void GroovesharkService::EnsureMenuCreated() {
get_url_to_share_song_ = context_menu_->addAction(
tr("Get an URL to share this Grooveshark song"),
this, SLOT(GetCurrentSongUrlToShare()));
+ get_url_to_share_playlist_ = context_menu_->addAction(
+ tr("Get an URL to share this Grooveshark playlist"),
+ this, SLOT(GetCurrentPlaylistUrlToShare()));
context_menu_->addSeparator();
context_menu_->addAction(IconLoader::Load("edit-find"),
tr("Search Grooveshark (opens a new tab)") + "...",
@@ -1071,9 +1090,34 @@ void GroovesharkService::SongUrlToShareReceived(QNetworkReply* reply) {
if (!result["url"].isValid())
return;
QString url = result["url"].toString();
+ ShowUrlBox(tr("Grooveshark song's URL"), url);
+}
+void GroovesharkService::GetCurrentPlaylistUrlToShare() {
+ GetPlaylistUrlToShare(current_playlist_id_);
+}
+
+void GroovesharkService::GetPlaylistUrlToShare(int playlist_id) {
+ QList parameters;
+ parameters << Param("playlistID", playlist_id);
+ QNetworkReply* reply = CreateRequest("getPlaylistURLFromPlaylistID", parameters);
+
+ NewClosure(reply, SIGNAL(finished()), this,
+ SLOT(PlaylistUrlToShareReceived(QNetworkReply*)), reply);
+}
+
+void GroovesharkService::PlaylistUrlToShareReceived(QNetworkReply* reply) {
+ reply->deleteLater();
+ QVariantMap result = ExtractResult(reply);
+ if (!result["url"].isValid())
+ return;
+ QString url = result["url"].toString();
+ ShowUrlBox(tr("Grooveshark playlist's URL"), url);
+}
+
+void GroovesharkService::ShowUrlBox(const QString& title, const QString& url) {
QMessageBox url_box;
- url_box.setWindowTitle(tr("Grooveshark song's URL"));
+ url_box.setWindowTitle(title);
url_box.setWindowIcon(QIcon(":/icon.png"));
url_box.setText(url);
url_box.setStandardButtons(QMessageBox::Ok);
diff --git a/src/internet/groovesharkservice.h b/src/internet/groovesharkservice.h
index 1dfafb896..92d451878 100644
--- a/src/internet/groovesharkservice.h
+++ b/src/internet/groovesharkservice.h
@@ -98,6 +98,7 @@ class GroovesharkService : public InternetService {
void AddUserFavoriteSong(int song_id);
void RemoveFromFavorites(int song_id);
void GetSongUrlToShare(int song_id);
+ void GetPlaylistUrlToShare(int playlist_id);
// Start autoplay for the given tag_id, fill the autoplay_state, returns a
// first song to play
Song StartAutoplayTag(int tag_id, QVariantMap& autoplay_state);
@@ -172,6 +173,8 @@ class GroovesharkService : public InternetService {
void UserFavoriteSongAdded(QNetworkReply* reply, int task_id);
void GetCurrentSongUrlToShare();
void SongUrlToShareReceived(QNetworkReply* reply);
+ void GetCurrentPlaylistUrlToShare();
+ void PlaylistUrlToShareReceived(QNetworkReply* reply);
void RemoveCurrentFromPlaylist();
void RemoveCurrentFromFavorites();
void SongRemovedFromFavorites(QNetworkReply* reply, int task_id);
@@ -205,6 +208,7 @@ class GroovesharkService : public InternetService {
// Convenient function which block until 'reply' replies, or timeout after 10
// seconds. Returns false if reply has timeouted
bool WaitForReply(QNetworkReply* reply);
+ void ShowUrlBox(const QString& title, const QString& url);
// Convenient function for extracting result from reply
QVariantMap ExtractResult(QNetworkReply* reply);
// Convenient function for extracting songs from grooveshark result. result
@@ -247,7 +251,10 @@ class GroovesharkService : public InternetService {
NetworkAccessManager* network_;
QMenu* context_menu_;
+ // IDs kept when showing menu, to know what the user has clicked on, to be
+ // able to perform actions on corresponding items
int current_song_id_;
+ int current_playlist_id_;
QAction* create_playlist_;
QAction* delete_playlist_;
@@ -255,6 +262,7 @@ class GroovesharkService : public InternetService {
QAction* remove_from_playlist_;
QAction* remove_from_favorites_;
QAction* get_url_to_share_song_;
+ QAction* get_url_to_share_playlist_;
QList playlistitem_actions_;
QTimer* search_delay_;