Clementine-audio-player-Mac.../src/internet/core/internetservice.h

165 lines
5.4 KiB
C++

/* This file is part of Clementine.
Copyright 2009-2012, David Sansome <me@davidsansome.com>
Copyright 2010, 2014, John Maguire <john.maguire@gmail.com>
Copyright 2011-2012, Arnaud Bienner <arnaud.bienner@gmail.com>
Copyright 2011, Tyler Rhodes <tyler.s.rhodes@gmail.com>
Copyright 2011, Paweł Bara <keirangtp@gmail.com>
Copyright 2014, Krzysztof Sobiecki <sobkas@gmail.com>
Clementine is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Clementine is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Clementine. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef INTERNET_CORE_INTERNETSERVICE_H_
#define INTERNET_CORE_INTERNETSERVICE_H_
#include <QAction>
#include <QList>
#include <QMenu>
#include <QObject>
#include <QUrl>
#include "core/lazy.h"
#include "core/song.h"
#include "playlist/playlistitem.h"
#include "smartplaylists/generator.h"
#include "ui/settingsdialog.h"
#include "widgets/multiloadingindicator.h"
class Application;
class InternetModel;
class LibraryFilterWidget;
class QJsonDocument;
class QNetworkReply;
class QStandardItem;
class InternetService : public QObject {
Q_OBJECT
public:
// Constructs a new internet service with the given name and model. The name
// should be user-friendly (like 'DigitallyImported' or 'Last.fm').
InternetService(const QString& name, Application* app, InternetModel* model,
QObject* parent = nullptr);
virtual ~InternetService() {}
// Convenient method that shows URL in a QMessageBox. Used by several Internet
// services
static void ShowUrlBox(const QString& title, const QString& url);
QString name() const { return name_; }
InternetModel* model() const { return model_; }
virtual QStandardItem* CreateRootItem() = 0;
virtual void LazyPopulate(QStandardItem* parent) = 0;
virtual bool has_initial_load_settings() const { return false; }
virtual void InitialLoadSettings() {}
virtual void ShowContextMenu(const QPoint& global_pos);
// Create a generator for smart playlists
virtual smart_playlists::GeneratorPtr CreateGenerator(QStandardItem* item) {
return smart_playlists::GeneratorPtr();
}
// Give the service a chance to do a custom action when data is dropped on it
virtual void DropMimeData(const QMimeData* data, const QModelIndex& index) {}
virtual PlaylistItem::Options playlistitem_options() const {
return PlaylistItem::Default;
}
// Redefine this function to add service' specific actions to the playlist
// item
virtual QList<QAction*> playlistitem_actions(const Song& song) {
return QList<QAction*>();
}
virtual QWidget* HeaderWidget() const { return nullptr; }
virtual void ReloadSettings() {}
virtual QString Icon() { return QString(); }
virtual bool ConfigRequired() { return false; }
signals:
void StreamError(const QString& message);
void StreamMetadataFound(const QUrl& original_url, const Song& song);
void AddToPlaylistSignal(QMimeData* data);
void ScrollToIndex(const QModelIndex& index);
public slots:
virtual void ShowConfig() {}
private slots:
void AppendToPlaylist();
void ReplacePlaylist();
void OpenInNewPlaylist();
protected:
// Called once when context menu is created
virtual void PopulateContextMenu(){};
// Called every time context menu is shown
virtual void UpdateContextMenu(){};
// Returns all the playlist insertion related QActions (see below).
QList<QAction*> GetPlaylistActions();
// Returns the 'append to playlist' QAction.
QAction* GetAppendToPlaylistAction();
// Returns the 'replace playlist' QAction.
QAction* GetReplacePlaylistAction();
// Returns the 'open in new playlist' QAction.
QAction* GetOpenInNewPlaylistAction();
// Check network reply for error, read, then parse. Will display errors if
// they occur. Returns a valid QJsonDocument on success, a null document on
// failure.
QJsonDocument ParseJsonReply(QNetworkReply* reply);
// Describes how songs should be added to playlist.
enum AddMode {
// appends songs to the current playlist
AddMode_Append,
// clears the current playlist and then appends all songs to it
AddMode_Replace,
// creates a new, empty playlist and then adds all songs to it
AddMode_OpenInNew
};
// Adds the 'index' element to playlist using the 'add_mode' mode.
void AddItemToPlaylist(const QModelIndex& index, AddMode add_mode);
// Adds the 'indexes' elements to playlist using the 'add_mode' mode.
void AddItemsToPlaylist(const QModelIndexList& indexes, AddMode add_mode);
// Convenient function for creating a item representing a song.
// Set some common properties (type=track, url, etc.)
QStandardItem* CreateSongItem(const Song& song);
protected:
Application* app_;
std::unique_ptr<QMenu> context_menu_;
private:
InternetModel* model_;
QString name_;
Lazy<QAction> append_to_playlist_;
Lazy<QAction> replace_playlist_;
Lazy<QAction> open_in_new_playlist_;
Lazy<QAction> separator_;
};
Q_DECLARE_METATYPE(InternetService*)
#endif // INTERNET_CORE_INTERNETSERVICE_H_