File indexing completed on 2025-10-19 04:34:00
0001 /**************************************************************************************** 0002 * Copyright (c) 2008 Nikolaj Hald Nielsen <nhn@kde.org> * 0003 * * 0004 * This program is free software; you can redistribute it and/or modify it under * 0005 * the terms of the GNU General Public License as published by the Free Software * 0006 * Foundation; either version 2 of the License, or (at your option) any later * 0007 * version. * 0008 * * 0009 * This program is distributed in the hope that it will be useful, but WITHOUT ANY * 0010 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A * 0011 * PARTICULAR PURPOSE. See the GNU General Public License for more details. * 0012 * * 0013 * You should have received a copy of the GNU General Public License along with * 0014 * this program. If not, see <http://www.gnu.org/licenses/>. * 0015 ****************************************************************************************/ 0016 0017 #ifndef SOURCEINFOCAPABILITY_H 0018 #define SOURCEINFOCAPABILITY_H 0019 0020 #include "core/amarokcore_export.h" 0021 #include "core/capabilities/Capability.h" 0022 0023 class QPixmap; 0024 0025 namespace Capabilities 0026 { 0027 0028 /** 0029 This capability allows getting additional information about the source of a meta item. For now, it is intended for allowing the playlist to display a little emblem to let users know if a track is a Magnatune preview track, a lastfm stream or so on... 0030 0031 @author Nikolaj Hald Nielsen <nhn@kde.org> 0032 */ 0033 class AMAROKCORE_EXPORT SourceInfoCapability : public Capabilities::Capability{ 0034 public: 0035 Q_OBJECT 0036 public: 0037 /** 0038 * Constructor 0039 */ 0040 SourceInfoCapability(); 0041 /** 0042 * Destructor 0043 */ 0044 ~SourceInfoCapability() override; 0045 0046 /** 0047 * Get the human readable name of the source, for instance "Magnatune.com" 0048 * @return The name of the source 0049 */ 0050 virtual QString sourceName() = 0; 0051 /** 0052 * Get a brief human readable description or the source 0053 * @return The source description 0054 */ 0055 virtual QString sourceDescription() = 0; 0056 /** 0057 * Get a small 16x16 pixle emblem that represents the source. 0058 * @return The source emblem 0059 */ 0060 virtual QPixmap emblem() = 0; 0061 0062 /** 0063 * Get a path to a scalable (svg) version of the source emblem. 0064 */ 0065 virtual QString scalableEmblem() = 0; 0066 0067 /** 0068 * Get the capabilityInterfaceType of this capability 0069 * @return The capabilityInterfaceType ( always Capabilities::Capability::SourceInfo; ) 0070 */ 0071 static Type capabilityInterfaceType() { return Capabilities::Capability::SourceInfo; } 0072 0073 }; 0074 0075 } 0076 0077 #endif