1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
|
/***************************************************************************
* copyright : (c) 2004 Pierpaolo Di Panfilo *
* (c) 2004 Mark Kretschmann <[email protected]> *
* (c) 2005-2006 Seb Ruiz <[email protected]> *
* (c) 2005 Gábor Lehel <[email protected]> *
* (c) 2006 Adam Pigg <[email protected]> *
* See COPYING file for licensing information *
***************************************************************************/
#ifndef PLAYLISTBROWSER_H
#define PLAYLISTBROWSER_H
#include "amarokconfig.h"
#include "playlistbrowseritem.h"
#include "podcastsettings.h"
#include <kaction.h>
#include <klistview.h>
#include <kpushbutton.h>
#include <kurl.h>
#include <qdom.h>
#include <qptrlist.h>
#include <qvbox.h>
class KTextBrowser;
class KToolBar;
class QCustomEvent;
class QColorGroup;
class QDragObject;
class QPainter;
class QPixmap;
class QPoint;
class QSplitter;
class QTimer;
class HTMLView;
class InfoPane;
class PlaylistBrowserView;
class PlaylistTrackItem;
class PlaylistBrowser : public QVBox
{
Q_OBJECT
friend class DynamicMode;
friend class PlaylistBrowserView;
friend class PlaylistBrowserEntry;
friend class PlaylistCategory;
friend class PlaylistEntry;
friend class PlaylistTrackItem;
friend class PodcastChannel; //for changing podcast timer list
friend class PodcastEpisode;
friend class DynamicEntry;
friend class StreamEntry;
friend class SmartPlaylist;
public:
enum AddMode { PLAYLIST, PLAYLIST_IMPORT, STREAM, SMARTPLAYLIST, PODCAST, ADDDYNAMIC };
~PlaylistBrowser();
void setInfo( const QString &title, const QString &info );
void addStream( QListViewItem *parent = 0 );
void addSmartPlaylist( QListViewItem *parent = 0 );
void addDynamic( QListViewItem *parent = 0 );
void addPlaylist( const QString &path, QListViewItem *parent = 0, bool force=false, bool imported=false );
PlaylistEntry *findPlaylistEntry( const QString &url, QListViewItem *parent=0 ) const;
int loadPlaylist( const QString &playlist, bool force=false );
void addPodcast( QListViewItem *parent = 0 );
void addPodcast( const KURL &url, QListViewItem *parent = 0 );
void loadPodcastsFromDatabase( PlaylistCategory *p = 0 );
void registerPodcastSettings( const QString &title, const PodcastSettings *settings );
static bool savePlaylist( const QString &path, const QValueList<KURL> &urls,
const QValueList<QString> &titles = QValueList<QString>(),
const QValueList<int> &lengths = QValueList<int>(),
bool relative = AmarokConfig::relativePlaylist() );
QString dynamicBrowserCache() const;
QString playlistBrowserCache() const;
QString podcastBrowserCache() const;
QString streamBrowserCache() const;
QString smartplaylistBrowserCache() const;
PlaylistBrowserEntry *findItem( QString &t, int c ) const;
QListViewItem *findItemInTree( const QString &searchstring, int c ) const;
PodcastEpisode *findPodcastEpisode( const KURL &episode, const KURL &feed ) const;
QPtrList<PlaylistBrowserEntry> dynamicEntries() const { return m_dynamicEntries; }
DynamicMode *findDynamicModeByTitle( const QString &title );
QListViewItem *podcastCategory() const { return m_podcastCategory; }
static PlaylistBrowser *instance() {
if(!s_instance) s_instance = new PlaylistBrowser("PlaylistBrowser");
return s_instance;
}
//following used by PlaylistSelection.cpp
PlaylistBrowserView* getListView() const { return m_listview; }
PlaylistCategory* getDynamicCategory() const { return m_dynamicCategory; }
void saveDynamics();
protected:
virtual void resizeEvent( QResizeEvent * );
signals:
void selectionChanged();
public slots:
void openPlaylist( QListViewItem *parent = 0 );
void scanPodcasts();
private slots:
void abortPodcastQueue();
void addSelectedToPlaylist( int options = -1 );
void collectionScanDone();
void currentItemChanged( QListViewItem * );
void downloadPodcastQueue();
void editStreamURL( StreamEntry *item, const bool readOnly=false );
void removeSelectedItems();
void renamePlaylist( QListViewItem*, const QString&, int );
void renameSelectedItem();
void invokeItem( QListViewItem*, const QPoint &, int column );
void slotDoubleClicked( QListViewItem *item );
void slotAddMenu( int id );
void slotAddPlaylistMenu( int id );
void showContextMenu( QListViewItem*, const QPoint&, int );
void loadDynamicItems();
private:
PlaylistBrowser( const char* name=0 );
void polish();
bool m_polished;
PlaylistCategory* loadStreams();
void loadCoolStreams();
void saveStreams();
void loadLastfmStreams( const bool subscriber = false );
void addLastFmRadio( QListViewItem *parent );
void addLastFmCustomRadio( QListViewItem *parent );
void saveLastFm();
PlaylistCategory* loadSmartPlaylists();
void loadDefaultSmartPlaylists();
void editSmartPlaylist( SmartPlaylist* );
void saveSmartPlaylists( PlaylistCategory *smartCategory = NULL );
void updateSmartPlaylists( QListViewItem *root );
void updateSmartPlaylistElement( QDomElement& query );
PlaylistCategory* loadDynamics();
void fixDynamicPlaylistPath( QListViewItem *item );
QString guessPathFromPlaylistName( QString name );
PlaylistCategory* loadPodcasts();
QMap<int,PlaylistCategory*> loadPodcastFolders( PlaylistCategory *p );
void changePodcastInterval();
void configurePodcasts( QListViewItem *parent );
void configurePodcasts( QPtrList<PodcastChannel> &podcastChannelList, const QString &caption );
void configureSelectedPodcasts();
bool deleteSelectedPodcastItems( const bool removeItem=false, const bool silent=false );
bool deletePodcasts( QPtrList<PodcastChannel> items );
void downloadSelectedPodcasts();
void refreshPodcasts( QListViewItem *category );
void removePodcastFolder( PlaylistCategory *item );
void savePodcastFolderStates( PlaylistCategory *folder );
PodcastChannel *findPodcastChannel( const KURL &feed, QListViewItem *parent=0 ) const;
void markDynamicEntries();
PlaylistBrowserEntry* findByName( QString name );
PlaylistCategory* loadPlaylists();
void savePlaylists();
void savePlaylist( PlaylistEntry * );
bool createPlaylist( QListViewItem *parent = 0, bool current = true, QString title = 0 );
bool deletePlaylists( QPtrList<PlaylistEntry> items );
bool deletePlaylists( KURL::List items );
void customEvent( QCustomEvent* e );
void saveM3U( PlaylistEntry *, bool append );
void savePLS( PlaylistEntry *, bool append );
void saveXSPF( PlaylistEntry *, bool append );
static KURL::List recurse( const KURL &url );
static PlaylistBrowser *s_instance;
PlaylistCategory *m_playlistCategory;
PlaylistCategory *m_streamsCategory;
PlaylistCategory *m_smartCategory;
PlaylistCategory *m_dynamicCategory;
PlaylistCategory *m_podcastCategory;
PlaylistCategory *m_coolStreams;
PlaylistCategory *m_smartDefaults;
PlaylistCategory *m_lastfmCategory;
ShoutcastBrowser *m_shoutcastCategory;
PlaylistEntry *m_lastPlaylist;
DynamicEntry *m_randomDynamic;
DynamicEntry *m_suggestedDynamic;
bool m_coolStreamsOpen;
bool m_smartDefaultsOpen;
bool m_lastfmOpen;
PlaylistBrowserView *m_listview;
KActionCollection *m_ac;
KAction *removeButton;
KAction *renameButton;
KActionMenu *viewMenuButton;
KActionMenu *addMenuButton;
KToolBar *m_toolbar;
QValueList<int> m_dynamicSizeSave;
QDict<PodcastSettings> m_podcastSettings;
QPtrList<PlaylistBrowserEntry> m_dynamicEntries;
QTimer *m_podcastTimer;
int m_podcastTimerInterval; //in ms
QPtrList<PodcastChannel> m_podcastItemsToScan;
QPtrList<PodcastEpisode> m_podcastDownloadQueue;
InfoPane *m_infoPane;
bool m_removeDirt;
QSplitter *m_splitter;
};
class PlaylistBrowserView : public KListView
{
Q_OBJECT
friend class PlaylistEntry;
public:
PlaylistBrowserView( QWidget *parent, const char *name=0 );
~PlaylistBrowserView();
void rename( QListViewItem *item, int c );
protected:
virtual void keyPressEvent( QKeyEvent * );
private slots:
void mousePressed( int, QListViewItem *, const QPoint &, int );
void moveSelectedItems( QListViewItem* newParent );
private:
void startDrag();
void contentsDropEvent( QDropEvent* );
void contentsDragEnterEvent( QDragEnterEvent* );
void contentsDragMoveEvent( QDragMoveEvent* );
void contentsDragLeaveEvent( QDragLeaveEvent* );
void viewportPaintEvent( QPaintEvent* );
void eraseMarker();
QListViewItem *m_marker; //track that has the drag/drop marker under it
};
class PlaylistDialog: public KDialogBase
{
Q_OBJECT
public:
static QString getSaveFileName( const QString &suggestion = QString::null, bool proposeOverwriting = false );
private:
KLineEdit *edit;
bool customChosen;
QString result;
PlaylistDialog();
private slots:
void slotOk();
void slotTextChanged( const QString &s );
void slotCustomPath();
};
// Returns true if item is Playlist, Stream, Smart Playlist or DynamicMode.
inline bool
isElement( QListViewItem *item )
{
if( !item )
return false;
return item->rtti() == ( PlaylistEntry::RTTI || StreamEntry::RTTI ||
SmartPlaylist::RTTI /*|| DynamicEntry::RTTI */) ? true : false;
}
inline bool
isCategory( QListViewItem *item )
{
if( !item )
return false;
return item->rtti() == PlaylistCategory::RTTI ? true : false;
}
inline bool
isDynamic( QListViewItem *item )
{
if( !item )
return false;
return item->rtti() == DynamicEntry::RTTI ? true : false;
}
inline bool
isPlaylist( QListViewItem *item )
{
if( !item )
return false;
return item->rtti() == PlaylistEntry::RTTI ? true : false;
}
inline bool
isSmartPlaylist( QListViewItem *item )
{
if( !item )
return false;
return item->rtti() == SmartPlaylist::RTTI ? true : false;
}
inline bool
isPlaylistTrackItem( QListViewItem *item )
{
if( !item )
return false;
return item->rtti() == PlaylistTrackItem::RTTI ? true : false;
}
inline bool
isPodcastChannel( QListViewItem *item )
{
if( !item )
return false;
return item->rtti() == PodcastChannel::RTTI ? true : false;
}
inline bool
isPodcastEpisode( QListViewItem *item )
{
if( !item )
return false;
return item->rtti() == PodcastEpisode::RTTI ? true : false;
}
inline bool
isStream( QListViewItem *item )
{
if( !item )
return false;
return item->rtti() == StreamEntry::RTTI ? true : false;
}
inline bool
isLastFm( QListViewItem *item )
{
if( !item )
return false;
return item->rtti() == LastFmEntry::RTTI ? true : false;
}
inline QString
fileBaseName( const QString &filePath )
{
// this function returns the file name without extension
// (e.g. if the file path is "/home/user/playlist.m3u", "playlist" is returned
QString fileName = filePath.right( filePath.length() - filePath.findRev( '/' ) - 1 );
return fileName.mid( 0, fileName.findRev( '.' ) );
}
inline QString
fileDirPath( const QString &filePath )
{
return filePath.left( filePath.findRev( '/' )+1 );
}
class InfoPane : public QVBox
{
Q_OBJECT
public:
InfoPane( QWidget *parent );
~InfoPane();
int getHeight();
void setStoredHeight( const int newHeight );
public slots:
void setInfo( const QString &title, const QString &info );
private slots:
void toggle( bool );
private:
HTMLView *m_infoBrowser;
KPushButton *m_pushButton;
bool m_enable;
int m_storedHeight;
};
#endif
|