void ProjectList::slotEditClip()
{
ProjectItem *item;
- if (m_listView->currentItem()->type() == QTreeWidgetItem::UserType + 1) {
+ if (!m_listView->currentItem() || m_listView->currentItem()->type() == PROJECTFOLDERTYPE) return;
+ if (m_listView->currentItem()->type() == PROJECTSUBCLIPTYPE) {
item = static_cast <ProjectItem*>(m_listView->currentItem()->parent());
} else item = static_cast <ProjectItem*>(m_listView->currentItem());
if (!(item->flags() & Qt::ItemIsDragEnabled)) return;
- if (item && !item->isGroup()) {
+ if (item) {
emit clipSelected(item->referencedClip());
emit showClipProperties(item->referencedClip());
}
void ProjectList::slotOpenClip()
{
ProjectItem *item;
+ if (!m_listView->currentItem() || m_listView->currentItem()->type() == PROJECTFOLDERTYPE) return;
if (m_listView->currentItem()->type() == QTreeWidgetItem::UserType + 1) {
item = static_cast <ProjectItem*>(m_listView->currentItem()->parent());
} else item = static_cast <ProjectItem*>(m_listView->currentItem());
- if (item && !item->isGroup()) {
+ if (item) {
if (item->clipType() == IMAGE) {
if (KdenliveSettings::defaultimageapp().isEmpty()) KMessageBox::sorry(this, i18n("Please set a default application to open images in the Settings dialog"));
else QProcess::startDetached(KdenliveSettings::defaultimageapp(), QStringList() << item->clipUrl().path());
QTreeWidgetItemIterator it(m_listView);
ProjectItem *item;
while (*it) {
- if ((*it)->type() == QTreeWidgetItem::UserType + 1) {
+ if ((*it)->type() != PROJECTCLIPTYPE) {
it++;
continue;
}
item = static_cast <ProjectItem *>(*it);
- if (!item->isGroup() && item->numReferences() == 0) item->setSelected(true);
+ if (item->numReferences() == 0) item->setSelected(true);
it++;
}
slotRemoveClip();
QStringList ids;
QStringList urls;
while (*it) {
- if ((*it)->type() == QTreeWidgetItem::UserType + 1) {
+ if ((*it)->type() != PROJECTCLIPTYPE) {
it++;
continue;
}
item = static_cast <ProjectItem *>(*it);
- if (!item->isGroup() && item->numReferences() == 0) {
+ if (item->numReferences() == 0) {
ids << item->clipId();
KUrl url = item->clipUrl();
if (!url.isEmpty() && !urls.contains(url.path())) urls << url.path();
// Check that we don't use the URL in another clip
QTreeWidgetItemIterator it2(m_listView);
while (*it2) {
- if ((*it2)->type() == QTreeWidgetItem::UserType + 1) {
+ if ((*it2)->type() != PROJECTCLIPTYPE) {
it2++;
continue;
}
else selected.append(getItemById(id));
ProjectItem *item;
for (int i = 0; i < selected.count(); i++) {
- if (selected.at(i)->type() == QTreeWidgetItem::UserType + 1) continue;
+ if (selected.at(i)->type() != PROJECTCLIPTYPE) continue;
item = static_cast <ProjectItem *>(selected.at(i));
- if (item && !item->isGroup()) {
+ if (item) {
if (item->clipType() == IMAGE) {
item->referencedClip()->producer()->set("force_reload", 1);
} else if (item->clipType() == TEXT) {
void ProjectList::slotClipSelected()
{
- if (m_listView->currentItem()) {
+ if (m_listView->currentItem() && m_listView->currentItem()->type() != PROJECTFOLDERTYPE) {
ProjectItem *clip;
- if (m_listView->currentItem()->type() == QTreeWidgetItem::UserType + 1) {
+ if (m_listView->currentItem()->type() == PROJECTSUBCLIPTYPE) {
// this is a sub item, use base clip
clip = static_cast <ProjectItem*>(m_listView->currentItem()->parent());
if (clip == NULL) kDebug() << "-----------ERROR";
return;
}
clip = static_cast <ProjectItem*>(m_listView->currentItem());
- if (!clip->isGroup()) {
- emit clipSelected(clip->referencedClip());
- }
+ emit clipSelected(clip->referencedClip());
m_editAction->setEnabled(true);
m_deleteAction->setEnabled(true);
m_reloadAction->setEnabled(true);
void ProjectList::slotUpdateClipProperties(ProjectItem *clip, QMap <QString, QString> properties)
{
if (!clip) return;
- if (!clip->isGroup()) clip->setProperties(properties);
+ clip->setProperties(properties);
if (properties.contains("name")) {
m_listView->blockSignals(true);
clip->setText(1, properties.value("name"));
void ProjectList::slotItemEdited(QTreeWidgetItem *item, int column)
{
- if (item->type() == QTreeWidgetItem::UserType + 1) {
+ if (item->type() == PROJECTSUBCLIPTYPE) {
// this is a sub-item
return;
}
+ if (item->type() == PROJECTFOLDERTYPE) {
+ if (column != 1) return;
+ FolderProjectItem *folder = static_cast <FolderProjectItem*>(item);
+ editFolder(item->text(1), folder->groupName(), folder->clipId());
+ folder->setGroupName(item->text(1));
+ m_doc->clipManager()->addFolder(folder->clipId(), item->text(1));
+ const int children = item->childCount();
+ for (int i = 0; i < children; i++) {
+ ProjectItem *child = static_cast <ProjectItem *>(item->child(i));
+ child->setProperty("groupname", item->text(1));
+ }
+ return;
+ }
ProjectItem *clip = static_cast <ProjectItem*>(item);
if (column == 2) {
m_commandStack->push(command);
}
} else if (column == 1) {
- if (clip->isGroup()) {
- editFolder(item->text(1), clip->groupName(), clip->clipId());
- clip->setGroupName(item->text(1));
- m_doc->clipManager()->addFolder(clip->clipId(), item->text(1));
- const int children = item->childCount();
- for (int i = 0; i < children; i++) {
- ProjectItem *child = static_cast <ProjectItem *>(item->child(i));
- child->setProperty("groupname", item->text(1));
- }
- } else {
- if (clip->referencedClip()) {
- QMap <QString, QString> oldprops;
- QMap <QString, QString> newprops;
- oldprops["name"] = clip->referencedClip()->getProperty("name");
- newprops["name"] = item->text(1);
- slotUpdateClipProperties(clip, newprops);
- emit projectModified();
- EditClipCommand *command = new EditClipCommand(this, clip->clipId(), oldprops, newprops, false);
- m_commandStack->push(command);
- }
+ if (clip->referencedClip()) {
+ QMap <QString, QString> oldprops;
+ QMap <QString, QString> newprops;
+ oldprops["name"] = clip->referencedClip()->getProperty("name");
+ newprops["name"] = item->text(1);
+ slotUpdateClipProperties(clip, newprops);
+ emit projectModified();
+ EditClipCommand *command = new EditClipCommand(this, clip->clipId(), oldprops, newprops, false);
+ m_commandStack->push(command);
}
}
}
m_reloadAction->setEnabled(enable);
m_transcodeAction->setEnabled(enable);
if (enable) {
- ProjectItem *clip;
- if (m_listView->currentItem()->type() == QTreeWidgetItem::UserType + 1) {
+ ProjectItem *clip = NULL;
+ if (m_listView->currentItem()->type() == PROJECTSUBCLIPTYPE) {
clip = static_cast <ProjectItem*>(item->parent());
- } else clip = static_cast <ProjectItem*>(item);
- if (clip->clipType() == IMAGE && !KdenliveSettings::defaultimageapp().isEmpty()) {
+ } else if (m_listView->currentItem()->type() == PROJECTCLIPTYPE) clip = static_cast <ProjectItem*>(item);
+ if (clip && clip->clipType() == IMAGE && !KdenliveSettings::defaultimageapp().isEmpty()) {
m_openAction->setIcon(KIcon(KdenliveSettings::defaultimageapp()));
m_openAction->setEnabled(true);
- } else if (clip->clipType() == AUDIO && !KdenliveSettings::defaultaudioapp().isEmpty()) {
+ } else if (clip && clip->clipType() == AUDIO && !KdenliveSettings::defaultaudioapp().isEmpty()) {
m_openAction->setIcon(KIcon(KdenliveSettings::defaultaudioapp()));
m_openAction->setEnabled(true);
} else m_openAction->setEnabled(false);
delCommand->setText(i18n("Delete Clip Zone"));
for (int i = 0; i < selected.count(); i++) {
- if (selected.at(i)->type() == QTreeWidgetItem::UserType + 1) {
+ if (selected.at(i)->type() == PROJECTSUBCLIPTYPE) {
// subitem
SubProjectItem *sub = static_cast <SubProjectItem *>(selected.at(i));
ProjectItem *item = static_cast <ProjectItem *>(sub->parent());
new AddClipCutCommand(this, item->clipId(), sub->zone().x(), sub->zone().y(), true, delCommand);
continue;
}
- ProjectItem *item = static_cast <ProjectItem *>(selected.at(i));
- if (item->isGroup()) folderids[item->groupName()] = item->clipId();
- else ids << item->clipId();
- if (item->numReferences() > 0) {
- if (KMessageBox::questionYesNo(this, i18np("Delete clip <b>%2</b>?<br>This will also remove the clip in timeline", "Delete clip <b>%2</b>?<br>This will also remove its %1 clips in timeline", item->numReferences(), item->names().at(1)), i18n("Delete Clip")) != KMessageBox::Yes) return;
- } else if (item->isGroup() && item->childCount() > 0) {
- int children = item->childCount();
- if (KMessageBox::questionYesNo(this, i18np("Delete folder <b>%2</b>?<br>This will also remove the clip in that folder", "Delete folder <b>%2</b>?<br>This will also remove the %1 clips in that folder", children, item->names().at(1)), i18n("Delete Folder")) != KMessageBox::Yes) return;
+
+ if (selected.at(i)->type() == PROJECTFOLDERTYPE) {
+ // folder
+ FolderProjectItem *folder = static_cast <FolderProjectItem *>(selected.at(i));
+ folderids[folder->groupName()] = folder->clipId();
+ int children = folder->childCount();
+
+ if (children > 0 && KMessageBox::questionYesNo(this, i18np("Delete folder <b>%2</b>?<br>This will also remove the clip in that folder", "Delete folder <b>%2</b>?<br>This will also remove the %1 clips in that folder", children, folder->text(1)), i18n("Delete Folder")) != KMessageBox::Yes) return;
for (int i = 0; i < children; ++i) {
- ProjectItem *child = static_cast <ProjectItem *>(item->child(i));
+ ProjectItem *child = static_cast <ProjectItem *>(folder->child(i));
ids << child->clipId();
}
+ continue;
+ }
+
+ ProjectItem *item = static_cast <ProjectItem *>(selected.at(i));
+ ids << item->clipId();
+ if (item->numReferences() > 0) {
+ if (KMessageBox::questionYesNo(this, i18np("Delete clip <b>%2</b>?<br>This will also remove the clip in timeline", "Delete clip <b>%2</b>?<br>This will also remove its %1 clips in timeline", item->numReferences(), item->names().at(1)), i18n("Delete Clip")) != KMessageBox::Yes) return;
}
}
if (delCommand->childCount() == 0) delete delCommand;
void ProjectList::slotAddFolder(const QString foldername, const QString &clipId, bool remove, bool edit)
{
if (remove) {
- ProjectItem *item = getFolderItemById(clipId);
+ FolderProjectItem *item = getFolderItemById(clipId);
if (item) {
m_doc->clipManager()->deleteFolder(clipId);
delete item;
}
} else {
if (edit) {
- ProjectItem *item = getFolderItemById(clipId);
+ FolderProjectItem *item = getFolderItemById(clipId);
if (item) {
m_listView->blockSignals(true);
item->setGroupName(foldername);
QStringList text;
text << QString() << foldername;
m_listView->blockSignals(true);
- m_listView->setCurrentItem(new ProjectItem(m_listView, text, clipId));
+ m_listView->setCurrentItem(new FolderProjectItem(m_listView, text, clipId));
m_doc->clipManager()->addFolder(clipId, foldername);
m_listView->blockSignals(false);
}
const QString parent = clip->getProperty("groupid");
ProjectItem *item = NULL;
if (!parent.isEmpty()) {
- ProjectItem *parentitem = getFolderItemById(parent);
+ FolderProjectItem *parentitem = getFolderItemById(parent);
if (!parentitem) {
QStringList text;
QString groupName = clip->getProperty("groupname");
//kDebug() << "Adding clip to new group: " << groupName;
if (groupName.isEmpty()) groupName = i18n("Folder");
text << QString() << groupName;
- parentitem = new ProjectItem(m_listView, text, parent);
+ parentitem = new FolderProjectItem(m_listView, text, parent);
} else {
//kDebug() << "Adding clip to existing group: " << parentitem->groupName();
}
ProjectItem *item;
m_listView->blockSignals(true);
while (*it) {
- if ((*it)->type() == QTreeWidgetItem::UserType + 1) {
+ if ((*it)->type() == PROJECTSUBCLIPTYPE) {
// subitem
SubProjectItem *sub = static_cast <SubProjectItem *>(*it);
if (sub->icon(0).isNull()) {
}
++it;
continue;
+ } else if ((*it)->type() == PROJECTFOLDERTYPE) {
+ // folder
+ ++it;
+ continue;
}
item = static_cast <ProjectItem *>(*it);
- if (!item->isGroup()) {
- clip = item->referencedClip();
- if (item->referencedClip()->producer() == NULL) {
- if (clip->isPlaceHolder() == false) {
- requestClipInfo(clip->toXML(), clip->getId());
- } else item->setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled);
- } else {
- if (item->icon(0).isNull()) {
- requestClipThumbnail(clip->getId());
- }
- if (item->data(1, DurationRole).toString().isEmpty()) {
- item->changeDuration(item->referencedClip()->producer()->get_playtime());
- }
+ clip = item->referencedClip();
+ if (item->referencedClip()->producer() == NULL) {
+ if (clip->isPlaceHolder() == false) {
+ requestClipInfo(clip->toXML(), clip->getId());
+ } else item->setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled);
+ } else {
+ if (item->icon(0).isNull()) {
+ requestClipThumbnail(clip->getId());
+ }
+ if (item->data(1, DurationRole).toString().isEmpty()) {
+ item->changeDuration(item->referencedClip()->producer()->get_playtime());
}
- item->setData(1, UsageRole, QString::number(item->numReferences()));
- //qApp->processEvents();
}
+ item->setData(1, UsageRole, QString::number(item->numReferences()));
+ //qApp->processEvents();
++it;
}
qApp->processEvents();
QStringList ProjectList::getGroup() const
{
QStringList result;
- ProjectItem *item = NULL;
- if (m_listView->currentItem() && m_listView->currentItem()->type() == QTreeWidgetItem::UserType + 1) {
- // sub item selected
- item = static_cast <ProjectItem*>(m_listView->currentItem()->parent());
- } else item = static_cast <ProjectItem*>(m_listView->currentItem());
- if (item && !item->isGroup()) {
- while (item->parent()) {
- item = static_cast <ProjectItem*>(item->parent());
- if (item->isGroup()) break;
- }
+ QTreeWidgetItem *item = m_listView->currentItem();
+ while (item && item->type() != PROJECTFOLDERTYPE) {
+ item = item->parent();
}
- if (item && item->isGroup()) {
- result << item->groupName();
- result << item->clipId();
+
+ if (item) {
+ FolderProjectItem *folder = static_cast <FolderProjectItem *>(item);
+ result << folder->groupName();
+ result << folder->clipId();
} else result << QString() << QString();
return result;
}
QMapIterator<QString, QString> f(flist);
while (f.hasNext()) {
f.next();
- (void) new ProjectItem(m_listView, QStringList() << QString() << f.value(), f.key());
+ (void) new FolderProjectItem(m_listView, QStringList() << QString() << f.value(), f.key());
}
QList <DocClipBase*> list = doc->clipManager()->documentClipList();
kDebug() << "//////////// PRO LISTĀ BUILD PRDSLIST ";
QTreeWidgetItemIterator it(m_listView);
while (*it) {
- if ((*it)->type() == QTreeWidgetItem::UserType + 1) {
+ if ((*it)->type() != PROJECTCLIPTYPE) {
// subitem
++it;
continue;
}
- if (!((ProjectItem *)(*it))->isGroup())
- prods.appendChild(doc.importNode(((ProjectItem *)(*it))->toXml(), true));
+ prods.appendChild(doc.importNode(((ProjectItem *)(*it))->toXml(), true));
++it;
}
return prods;
m_thumbnailQueue.clear();
QTreeWidgetItemIterator it(m_listView);
while (*it) {
- if ((*it)->type() == QTreeWidgetItem::UserType + 1) {
+ if ((*it)->type() != PROJECTCLIPTYPE) {
// subitem
++it;
continue;
}
- if (!((ProjectItem *)(*it))->isGroup())
- m_thumbnailQueue << ((ProjectItem *)(*it))->clipId();
+ m_thumbnailQueue << ((ProjectItem *)(*it))->clipId();
++it;
}
QTimer::singleShot(300, this, SLOT(slotProcessNextThumbnail()));
ProjectItem *item = NULL;
bool isSubItem = false;
int frame;
- if (it->type() == QTreeWidgetItem::UserType + 1) {
+ if (it->type() == PROJECTFOLDERTYPE) return;
+ if (it->type() == PROJECTSUBCLIPTYPE) {
item = static_cast <ProjectItem *>(it->parent());
frame = static_cast <SubProjectItem *>(it)->zone().x();
isSubItem = true;
if (item && producer) {
m_listView->blockSignals(true);
item->setProperties(properties, metadata);
- Q_ASSERT_X(item->referencedClip(), "void ProjectList::slotReplyGetFileProperties", QString("Item with groupName %1 does not have a clip associated").arg(item->groupName()).toLatin1());
+ //Q_ASSERT_X(item->referencedClip(), "void ProjectList::slotReplyGetFileProperties", QString("Item with groupName %1 does not have a clip associated").arg(item->groupName()).toLatin1());
item->referencedClip()->setProducer(producer, replace);
//emit receivedClipDuration(clipId);
if (m_listView->isEnabled() && replace) {
ProjectItem *result = NULL;
while (*it) {
- if ((*it)->type() == QTreeWidgetItem::UserType + 1) {
+ if ((*it)->type() != PROJECTCLIPTYPE) {
// subitem
++it;
continue;
}
ProjectItem *item = static_cast<ProjectItem *>(*it);
- if (item->clipId() == lookId && item->clipType() != FOLDER) {
+ if (item->clipId() == lookId) {
result = item;
break;
}
++it;
}
- if (!id.contains('#')) return result;
+ if (result == NULL || !id.contains('#')) return result;
else for (int i = 0; i < result->childCount(); i++) {
SubProjectItem *sub = static_cast <SubProjectItem *>(result->child(i));
if (sub && sub->zone().x() == id.section('#', 1, 1).toInt()) {
ProjectItem *item;
QTreeWidgetItemIterator it(m_listView);
while (*it) {
- if ((*it)->type() == QTreeWidgetItem::UserType + 1) {
+ if ((*it)->type() != PROJECTCLIPTYPE) {
// subitem
++it;
continue;
}
item = static_cast<ProjectItem *>(*it);
- if (item->clipId() == id && item->clipType() != FOLDER)
+ if (item->clipId() == id)
return item;
++it;
}
return NULL;
}
-ProjectItem *ProjectList::getFolderItemById(const QString &id)
+FolderProjectItem *ProjectList::getFolderItemById(const QString &id)
{
- ProjectItem *item;
+ FolderProjectItem *item;
QTreeWidgetItemIterator it(m_listView);
while (*it) {
- item = static_cast<ProjectItem *>(*it);
- if (item->clipId() == id && item->clipType() == FOLDER)
+ if ((*it)->type() == PROJECTFOLDERTYPE) {
+ item = static_cast<FolderProjectItem *>(*it);
return item;
+ }
++it;
}
return NULL;
QString ProjectList::currentClipUrl() const
{
ProjectItem *item;
- if (m_listView->currentItem()->type() == QTreeWidgetItem::UserType + 1) {
+ if (!m_listView->currentItem() || m_listView->currentItem()->type() == PROJECTFOLDERTYPE) return QString();
+ if (m_listView->currentItem()->type() == PROJECTSUBCLIPTYPE) {
// subitem
item = static_cast <ProjectItem*>(m_listView->currentItem()->parent());
} else item = static_cast <ProjectItem*>(m_listView->currentItem());
base->removeCutZone(in, out);
for (int i = 0; i < clip->childCount(); i++) {
QTreeWidgetItem *it = clip->child(i);
- if (it->type() != QTreeWidgetItem::UserType + 1) continue;
+ if (it->type() != PROJECTSUBCLIPTYPE) continue;
SubProjectItem *sub = static_cast <SubProjectItem*>(it);
if (sub->zone() == QPoint(in, out)) {
m_listView->blockSignals(true);
#include "projectlistview.h"
#include "projectitem.h"
#include "subprojectitem.h"
+#include "folderprojectitem.h"
#include "kdenlivesettings.h"
#include <KDebug>
{
QTreeWidgetItem *it = itemAt(event->pos());
if (!it) {
- emit addClip();
- return;
+ emit addClip();
+ return;
}
ProjectItem *item;
- if (it->type() == QTreeWidgetItem::UserType + 1) {
+ if (it->type() == PROJECTFOLDERTYPE) {
+ if ((columnAt(event->pos().x()) == 1)) QTreeWidget::mouseDoubleClickEvent(event);
+ return;
+ }
+ if (it->type() == PROJECTSUBCLIPTYPE) {
// subitem
item = static_cast <ProjectItem *>(it->parent());
} else item = static_cast <ProjectItem *>(it);
if (!(item->flags() & Qt::ItemIsDragEnabled)) return;
- if (item->isGroup()) {
- if ((columnAt(event->pos().x()) == 1)) QTreeWidget::mouseDoubleClickEvent(event);
- } else {
- if ((columnAt(event->pos().x()) == 1) && (item->clipType() == SLIDESHOW || item->clipType() == TEXT || item->clipType() == COLOR)) QTreeWidget::mouseDoubleClickEvent(event);
- else if ((columnAt(event->pos().x()) == 2) && it->type() != QTreeWidgetItem::UserType + 1) QTreeWidget::mouseDoubleClickEvent(event);
- else emit showProperties(item->referencedClip());
- }
+ if ((columnAt(event->pos().x()) == 1) && (item->clipType() == SLIDESHOW || item->clipType() == TEXT || item->clipType() == COLOR)) QTreeWidget::mouseDoubleClickEvent(event);
+ else if ((columnAt(event->pos().x()) == 2) && it->type() != PROJECTSUBCLIPTYPE) QTreeWidget::mouseDoubleClickEvent(event);
+ else emit showProperties(item->referencedClip());
}
// virtual
// virtual
void ProjectListView::dropEvent(QDropEvent *event)
{
- ProjectItem *item = NULL;
+ FolderProjectItem *item = NULL;
QTreeWidgetItem *it = itemAt(event->pos());
- if (it) {
- if (it->type() == QTreeWidgetItem::UserType + 1) {
- // subitem
- item = static_cast <ProjectItem *>(it->parent());
- } else item = static_cast <ProjectItem *>(it);
+ while (it && it->type() != PROJECTFOLDERTYPE) {
+ it = it->parent();
}
-
+ if (it) item = static_cast <FolderProjectItem *>(it);
if (event->mimeData()->hasUrls()) {
QString groupName;
QString groupId;
if (item) {
- if (item->parent()) item = static_cast <ProjectItem *>(item->parent());
- if (item->isGroup()) {
- groupName = item->groupName();
- groupId = item->clipId();
- }
+ groupName = item->groupName();
+ groupId = item->clipId();
}
emit addClip(event->mimeData()->urls(), groupName, groupId);
event->setDropAction(Qt::CopyAction);
return;
} else if (event->mimeData()->hasFormat("kdenlive/producerslist")) {
if (item) {
- if (item->parent()) item = static_cast <ProjectItem *>(item->parent());
- if (item->isGroup()) {
- //emit addClip(event->mimeData->text());
- const QList <QTreeWidgetItem *> list = selectedItems();
- ProjectItem *clone;
- QString parentId = item->clipId();
- foreach(QTreeWidgetItem *it, list) {
- // TODO allow dragging of folders ?
- if (!((ProjectItem *) it)->isGroup()/* && ((ProjectItem *) it)->clipId() < 10000*/) {
- if (it->parent()) clone = (ProjectItem*) it->parent()->takeChild(it->parent()->indexOfChild(it));
- else clone = (ProjectItem*) takeTopLevelItem(indexOfTopLevelItem(it));
- if (clone) {
- item->addChild(clone);
- QMap <QString, QString> props;
- props.insert("groupname", item->groupName());
- props.insert("groupid", parentId);
- clone->setProperties(props);
- }
+ //emit addClip(event->mimeData->text());
+ const QList <QTreeWidgetItem *> list = selectedItems();
+ ProjectItem *clone;
+ QString parentId = item->clipId();
+ foreach(QTreeWidgetItem *it, list) {
+ // TODO allow dragging of folders ?
+ if (it->type() == PROJECTCLIPTYPE) {
+ if (it->parent()) clone = (ProjectItem*) it->parent()->takeChild(it->parent()->indexOfChild(it));
+ else clone = (ProjectItem*) takeTopLevelItem(indexOfTopLevelItem(it));
+ if (clone) {
+ item->addChild(clone);
+ QMap <QString, QString> props;
+ props.insert("groupname", item->groupName());
+ props.insert("groupid", parentId);
+ clone->setProperties(props);
}
- }
- } else item = NULL;
- }
- if (!item) {
+ } else item = NULL;
+ }
+ } else {
// item dropped in empty zone, move it to top level
const QList <QTreeWidgetItem *> list = selectedItems();
ProjectItem *clone;
QTreeWidgetItem *it = itemAt(m_DragStartPosition);
if (!it) return;
- if (it->type() == QTreeWidgetItem::UserType + 1) {
+ if (it->type() == PROJECTSUBCLIPTYPE) {
// subitem
SubProjectItem *clickItem = static_cast <SubProjectItem *>(it);
if (clickItem && (clickItem->flags() & Qt::ItemIsDragEnabled)) {
drag->exec();
}
} else {
- ProjectItem *clickItem = static_cast <ProjectItem *>(it);
- if (clickItem && (clickItem->flags() & Qt::ItemIsDragEnabled)) {
+ if (it && (it->flags() & Qt::ItemIsDragEnabled)) {
QDrag *drag = new QDrag(this);
QMimeData *mimeData = new QMimeData;
const QList <QTreeWidgetItem *> list = selectedItems();
QStringList ids;
foreach(const QTreeWidgetItem *item, list) {
- const ProjectItem *clip = static_cast <const ProjectItem *>(item);
- if (!clip->isGroup()) ids.append(clip->clipId());
- else {
+ if (item->type() == PROJECTFOLDERTYPE) {
const int children = item->childCount();
for (int i = 0; i < children; i++) {
ids.append(static_cast <ProjectItem *>(item->child(i))->clipId());
}
+ } else {
+ const ProjectItem *clip = static_cast <const ProjectItem *>(item);
+ ids.append(clip->clipId());
}
}
if (ids.isEmpty()) return;
//mimeData->setText(ids.join(";")); //doc.toString());
//mimeData->setImageData(image);
drag->setMimeData(mimeData);
- drag->setPixmap(clickItem->icon(0).pixmap(iconSize()));
+ drag->setPixmap(it->icon(0).pixmap(iconSize()));
drag->setHotSpot(QPoint(0, 50));
drag->exec();
}