Members of the KDE Community are recommended to subscribe to the kde-community mailing list at https://mail.kde.org/mailman/listinfo/kde-community to allow them to participate in important discussions and receive other important announcements

dynamicplaylist.cpp 5.5 KB
Newer Older
1 2
/***************************************************************************
    begin                : Mon May 5 2003
3
    copyright            : (C) 2003 - 2004 by Scott Wheeler
4 5 6 7 8 9 10 11 12 13 14 15
    email                : wheeler@kde.org
***************************************************************************/

/***************************************************************************
 *                                                                         *
 *   This program 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 2 of the License, or     *
 *   (at your option) any later version.                                   *
 *                                                                         *
 ***************************************************************************/

16 17
#include <kdebug.h>

18 19
#include "dynamicplaylist.h"
#include "collectionlist.h"
20
#include "playlistcollection.h"
21
#include "tracksequencemanager.h"
22

23 24 25 26 27 28 29 30 31
class PlaylistDirtyObserver : public PlaylistObserver
{
public:
    PlaylistDirtyObserver(DynamicPlaylist *parent, Playlist *playlist) :
	PlaylistObserver(playlist),
        m_parent(parent) 
    {

    }
32 33
    virtual void updateData() { m_parent->slotSetDirty(); }
    virtual void updateCurrent() {}
34 35 36 37 38

private:
    DynamicPlaylist *m_parent;
};

39 40 41 42
////////////////////////////////////////////////////////////////////////////////
// public methods
////////////////////////////////////////////////////////////////////////////////

43 44 45
DynamicPlaylist::DynamicPlaylist(const PlaylistList &playlists,
                                 PlaylistCollection *collection,
                                 const QString &name,
46
                                 const QString &iconName,
47 48
                                 bool setupPlaylist,
                                 bool synchronizePlaying) :
49
    Playlist(collection, true),
50
    m_playlists(playlists),
51 52
    m_dirty(true),
    m_synchronizePlaying(synchronizePlaying)
53
{
54 55 56 57
    if(setupPlaylist)
        collection->setupPlaylist(this, iconName);
    setName(name);

58 59
    setSorting(columns() + 1);

60
    for(PlaylistList::ConstIterator it = playlists.begin(); it != playlists.end(); ++it)
61 62
        m_observers.append(new PlaylistDirtyObserver(this, *it));

63
    connect(CollectionList::instance(), SIGNAL(signalCollectionChanged()), this, SLOT(slotSetDirty()));
64 65
}

66 67
DynamicPlaylist::~DynamicPlaylist()
{
68
    lower();
69

70 71 72 73 74 75 76 77
    for(QValueList<PlaylistObserver *>::ConstIterator it = m_observers.begin();
        it != m_observers.end();
        ++it)
    {
        delete *it;
    }
}

78 79 80 81 82 83
void DynamicPlaylist::setPlaylists(const PlaylistList &playlists)
{
    m_playlists = playlists;
    updateItems();
}

84 85 86 87 88 89 90
////////////////////////////////////////////////////////////////////////////////
// public slots
////////////////////////////////////////////////////////////////////////////////

void DynamicPlaylist::slotReload()
{
    for(PlaylistList::Iterator it = m_playlists.begin(); it != m_playlists.end(); ++it)
91
        (*it)->slotReload();
92 93 94 95

    checkUpdateItems();
}

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
void DynamicPlaylist::lower(QWidget *top)
{
    if(top == this)
	return;

    if(playing()) {
        PlaylistList l;
        l.append(this);
        for(PlaylistList::Iterator it = m_playlists.begin();
            it != m_playlists.end(); ++it)
        {
            (*it)->synchronizePlayingItems(l, true);
        }
    }

    PlaylistItemList list = PlaylistItem::playingItems();
    for(PlaylistItemList::Iterator it = list.begin(); it != list.end(); ++it) {
        if((*it)->playlist() == this) {
            list.remove(it);
            break;
        }
    }

    if(!list.isEmpty())
        TrackSequenceManager::instance()->setCurrentPlaylist(list.front()->playlist());
}

123 124 125 126
////////////////////////////////////////////////////////////////////////////////
// protected methods
////////////////////////////////////////////////////////////////////////////////

127
PlaylistItemList DynamicPlaylist::items()
128
{
129 130
    checkUpdateItems();
    return Playlist::items();
131 132 133
}

void DynamicPlaylist::showEvent(QShowEvent *e)
134 135 136 137 138
{
    checkUpdateItems();
    Playlist::showEvent(e);
}

139 140 141 142 143 144
void DynamicPlaylist::paintEvent(QPaintEvent *e)
{
    checkUpdateItems();
    Playlist::paintEvent(e);
}

145
void DynamicPlaylist::updateItems()
146
{
147 148 149 150 151 152 153 154
    PlaylistItemList siblings;

    for(PlaylistList::ConstIterator it = m_playlists.begin(); it != m_playlists.end(); ++it)
        siblings += (*it)->items();


    PlaylistItemList newSiblings = siblings;
    if(m_siblings != newSiblings) {
155
        m_siblings = newSiblings;
156
        QTimer::singleShot(0, this, SLOT(slotUpdateItems()));
157
    }
158 159
}

160 161 162 163 164
bool DynamicPlaylist::synchronizePlaying() const
{
    return m_synchronizePlaying;
}

165 166 167 168 169 170 171
////////////////////////////////////////////////////////////////////////////////
// private methods
////////////////////////////////////////////////////////////////////////////////

void DynamicPlaylist::checkUpdateItems()
{
    if(!m_dirty)
172
        return;
173 174 175

    updateItems();

176
    m_dirty = false;
177 178
}

179 180 181 182 183 184 185 186 187 188
////////////////////////////////////////////////////////////////////////////////
// private slots
////////////////////////////////////////////////////////////////////////////////

void DynamicPlaylist::slotUpdateItems()
{
    // This should be optimized to check to see which items are already in the
    // list and just adding those and removing the ones that aren't.

    clear();
189
    createItems(m_siblings);
190 191
    if(m_synchronizePlaying)
        synchronizePlayingItems(m_playlists, true);
192 193
}

194
#include "dynamicplaylist.moc"