***************************************************************************/
-#ifndef PRJECTLIST_H
-#define PRJECTLIST_H
+#ifndef PROJECTLIST_H
+#define PROJECTLIST_H
#include <QDomNodeList>
#include <QToolBar>
+#include <QToolButton>
#include <QTreeWidget>
#include <QPainter>
+#include <QItemDelegate>
+#include <QUndoStack>
+
-#include <KUndoStack>
#include <KTreeWidgetSearchLine>
-#include <KExtendableItemDelegate>
+#include <KUrl>
+#include <nepomuk/kratingpainter.h>
+#include <nepomuk/resource.h>
#include "definitions.h"
-#include "kdenlivedoc.h"
-#include "renderer.h"
#include "timecode.h"
-#include "projectlistview.h"
+#include "kdenlivesettings.h"
+
+namespace Mlt
+{
+class Producer;
+};
class ProjectItem;
+class ProjectListView;
+class Render;
+class KdenliveDoc;
+class DocClipBase;
- const int NameRole = Qt::UserRole;
- const int DurationRole = NameRole + 1;
- const int FullPathRole = NameRole + 2;
- const int ClipTypeRole = NameRole + 3;
+const int NameRole = Qt::UserRole;
+const int DurationRole = NameRole + 1;
+const int UsageRole = NameRole + 2;
-class ItemDelegate: public KExtendableItemDelegate
+class ItemDelegate: public QItemDelegate
{
- public:
- ItemDelegate(QAbstractItemView* parent = 0): KExtendableItemDelegate(parent)
+public:
+ ItemDelegate(QAbstractItemView* parent = 0): QItemDelegate(parent) {
+ }
+ /*
+ static_cast<ProjectItem *>( index.internalPointer() );
+
+ void expand()
{
+ QWidget *w = new QWidget;
+ QVBoxLayout *layout = new QVBoxLayout;
+ layout->addWidget( new KColorButton(w));
+ w->setLayout( layout );
+ extendItem(w,
}
-/*
-void expand()
-{
- QWidget *w = new QWidget;
- QVBoxLayout *layout = new QVBoxLayout;
- layout->addWidget( new KColorButton(w));
- w->setLayout( layout );
- extendItem(w,
-}
-*/
-
-void paint(QPainter* painter, const QStyleOptionViewItem& option, const QModelIndex& index) const
-{
- if (index.column() == 1)
- {
- const bool hover = option.state & (QStyle::State_Selected|QStyle::State_MouseOver|QStyle::State_HasFocus);
- QRect r1 = option.rect;
- painter->save();
- if (hover) {
- painter->setPen(option.palette.color(QPalette::HighlightedText));
- QColor backgroundColor = option.palette.color(QPalette::Highlight);
- painter->setBrush(QBrush(backgroundColor));
- painter->fillRect(r1, QBrush(backgroundColor));
+ */
+ void paint(QPainter* painter, const QStyleOptionViewItem& option, const QModelIndex& index) const {
+ if (index.column() == 1) {
+ QRect r1 = option.rect;
+ painter->save();
+ if (option.state & (QStyle::State_Selected)) {
+ painter->setPen(option.palette.color(QPalette::HighlightedText));
+ painter->fillRect(r1, option.palette.highlight());
+ }
+ QFont font = painter->font();
+ font.setBold(true);
+ painter->setFont(font);
+ int mid = (int)((r1.height() / 2));
+ r1.setBottom(r1.y() + mid);
+ QRect r2 = option.rect;
+ r2.setTop(r2.y() + mid);
+ painter->drawText(r1, Qt::AlignLeft | Qt::AlignBottom , index.data().toString());
+ //painter->setPen(Qt::green);
+ font.setBold(false);
+ painter->setFont(font);
+ QString subText = index.data(DurationRole).toString();
+ int usage = index.data(UsageRole).toInt();
+ if (usage != 0) subText.append(QString(" (%1)").arg(usage));
+ painter->setPen(option.palette.color(QPalette::Mid));
+ painter->drawText(r2, Qt::AlignLeft | Qt::AlignVCenter , subText);
+ painter->restore();
+ } else if (index.column() == 3 && KdenliveSettings::activate_nepomuk()) {
+ if (index.data().toString().isEmpty()) {
+ QItemDelegate::paint(painter, option, index);
+ return;
+ }
+ QRect r1 = option.rect;
+ if (option.state & (QStyle::State_Selected)) {
+ painter->fillRect(r1, option.palette.highlight());
+ }
+ KRatingPainter::paintRating(painter, r1, Qt::AlignCenter, index.data().toInt());
+ } else {
+ QItemDelegate::paint(painter, option, index);
+ }
}
- QFont font = painter->font();
- font.setPointSize(font.pointSize() - 1 );
- font.setBold(true);
- painter->setFont(font);
- int mid = (int) ((r1.height() / 2 ));
- r1.setBottom(r1.y() + mid);
- QRect r2 = option.rect;
- r2.setTop(r2.y() + mid);
- painter->drawText(r1, Qt::AlignLeft | Qt::AlignBottom , index.data().toString());
- //painter->setPen(Qt::green);
- font.setBold(false);
- painter->setFont(font);
- painter->drawText(r2, Qt::AlignLeft | Qt::AlignVCenter , index.data(DurationRole).toString());
- painter->restore();
- }
- else
- {
- KExtendableItemDelegate::paint(painter, option, index);
- }
-}
};
class ProjectList : public QWidget
{
- Q_OBJECT
-
- public:
- ProjectList(QWidget *parent=0);
+ Q_OBJECT
+
+public:
+ ProjectList(QWidget *parent = 0);
virtual ~ProjectList();
QDomElement producersList();
void setRenderer(Render *projectRender);
-
- void addClip(const QStringList &name, const QDomElement &elem, const int clipId, const KUrl &url = KUrl(), const QString &group = QString::null, int parentId = -1);
- void deleteClip(const int clipId);
-
- public slots:
+ void slotUpdateClipProperties(const QString &id, QMap <QString, QString> properties);
+ void updateAllClips();
+ QByteArray headerInfo();
+ void setHeaderInfo(const QByteArray &state);
+ void setupMenu(QMenu *addMenu, QAction *defaultAction);
+ void setupGeneratorMenu(QMenu *addMenu);
+
+public slots:
void setDocument(KdenliveDoc *doc);
- void addProducer(QDomElement producer, int parentId = -1);
- void slotReplyGetImage(int clipId, int pos, const QPixmap &pix, int w, int h);
- void slotReplyGetFileProperties(int clipId, const QMap < QString, QString > &properties, const QMap < QString, QString > &metadata);
-
+ void slotReplyGetImage(const QString &clipId, const QPixmap &pix);
+ void slotReplyGetFileProperties(const QString &clipId, Mlt::Producer *producer, const QMap < QString, QString > &properties, const QMap < QString, QString > &metadata, bool replace);
+ void slotAddClip(DocClipBase *clip, bool getProperties);
+ void slotDeleteClip(const QString &clipId);
+ void slotUpdateClip(const QString &id);
+ void slotRefreshClipThumbnail(const QString &clipId, bool update = true);
+ void slotRefreshClipThumbnail(ProjectItem *item, bool update = true);
+ void slotRemoveInvalidClip(const QString &id);
+ void slotSelectClip(const QString &ix);
+ void slotRemoveClip();
+ void slotAddClip(const QList <QUrl> givenList = QList <QUrl> (), QString group = QString());
+ void slotAddFolder(const QString foldername, const QString &clipId, bool remove, bool edit = false);
+ void slotResetProjectList();
+ void slotOpenClip();
+ void slotEditClip();
+ void slotReloadClip();
- private:
- ProjectListView *listView;
- KTreeWidgetSearchLine *searchView;
+private:
+ ProjectListView *m_listView;
Render *m_render;
Timecode m_timecode;
double m_fps;
QToolBar *m_toolbar;
QMenu *m_menu;
- KUndoStack *m_commandStack;
- int m_clipIdCounter;
- void selectItemById(const int clipId);
- ProjectItem *getItemById(int id);
+ QUndoStack *m_commandStack;
+ void selectItemById(const QString &clipId);
+ ProjectItem *getItemById(const QString &id);
+ ProjectItem *getFolderItemById(const QString &id);
QAction *m_editAction;
QAction *m_deleteAction;
- ItemDelegate *m_listViewDelegate;
-
- private slots:
- void slotAddClip(QUrl givenUrl = QUrl(), const QString &group = QString::null);
- void slotRemoveClip();
- void slotEditClip();
+ QAction *m_openAction;
+ QAction *m_reloadAction;
+ KdenliveDoc *m_doc;
+ ProjectItem *m_selectedItem;
+ bool m_refreshed;
+ QToolButton *m_addButton;
+ QMap <QString, QDomElement> m_infoQueue;
+ void requestClipInfo(const QDomElement xml, const QString id);
+ QList <QString> m_thumbnailQueue;
+ void requestClipThumbnail(const QString &id);
+ void deleteProjectFolder(QMap <QString, QString> map);
+ void editFolder(const QString folderName, const QString oldfolderName, const QString &clipId);
+
+private slots:
void slotClipSelected();
void slotAddColorClip();
- void slotEditClip(QTreeWidgetItem *, int);
- void slotContextMenu( const QPoint &pos, QTreeWidgetItem * );
+ void slotAddSlideshowClip();
+ void slotAddTitleClip();
+ void slotContextMenu(const QPoint &pos, QTreeWidgetItem *);
void slotAddFolder();
/** This is triggered when a clip description has been modified */
- void slotUpdateItemDescription(QTreeWidgetItem *item, int column);
+ void slotItemEdited(QTreeWidgetItem *item, int column);
+ void slotUpdateClipProperties(ProjectItem *item, QMap <QString, QString> properties);
+ void slotProcessNextClipInQueue();
+ void slotProcessNextThumbnail();
+ void slotCheckForEmptyQueue();
+ void slotPauseMonitor();
//void slotShowMenu(const QPoint &pos);
-
-
- signals:
- void clipSelected(const QDomElement &);
- void getFileProperties(const QDomElement&, int);
- void receivedClipDuration(int, int);
+signals:
+ void clipSelected(DocClipBase *);
+ void getFileProperties(const QDomElement&, const QString &, bool);
+ void receivedClipDuration(const QString &);
+ void showClipProperties(DocClipBase *);
+ void projectModified();
+ void loadingIsOver();
+ void clipNameChanged(const QString, const QString);
};
#endif