Commit 8ccda514 authored by Vivek Yadav's avatar Vivek Yadav

edit name and description of custom effects

parent bb3b4265
......@@ -24,6 +24,8 @@
#include "effects/effectsrepository.hpp"
#include "transitions/transitionsrepository.hpp"
#include <QMessageBox>
int AssetTreeModel::nameCol = 0;
int AssetTreeModel::idCol = 1;
int AssetTreeModel::typeCol = 2;
......@@ -88,6 +90,80 @@ QString AssetTreeModel::getDescription(bool isEffect, const QModelIndex &index)
return QString();
}
QString AssetTreeModel::editCustomEffectInfo(const QString newName,const QString newDescription, const QModelIndex &index)
{
std::shared_ptr<TreeItem> item = getItemById((int)index.internalId());
QString currentName = item->dataColumn(AssetTreeModel::nameCol).toString();
QDomDocument doc;
QDomElement effect = EffectsRepository::get()->getXml(currentName);
QDir dir(QStandardPaths::writableLocation(QStandardPaths::AppDataLocation) + QStringLiteral("/effects/"));
QString oldpath = dir.absoluteFilePath(currentName + QStringLiteral(".xml"));
doc.appendChild(doc.importNode(effect, true));
if(!newDescription.trimmed().isEmpty()){
QDomElement root = doc.documentElement();
QDomElement nodelist = root.firstChildElement("description");
QDomElement newNodeTag = doc.createElement(QString("description"));
QDomText text = doc.createTextNode(newDescription);
newNodeTag.appendChild(text);
root.replaceChild(newNodeTag, nodelist);
}
if(!newName.trimmed().isEmpty())
{
QDir dir(QStandardPaths::writableLocation(QStandardPaths::AppDataLocation) + QStringLiteral("/effects/"));
if (!dir.exists()) {
dir.mkpath(QStringLiteral("."));
}
if (dir.exists(newName + QStringLiteral(".xml"))){
QMessageBox message;
message.critical(0, i18n("Error"), i18n("Effect name %1 already exists.\n Try another name?", newName));
message.setFixedSize(400, 200);
return oldpath;
}
QFile file(dir.absoluteFilePath(newName + QStringLiteral(".xml")));
QDomElement root = doc.documentElement();
QDomElement nodelist = root.firstChildElement("name");
QDomElement newNodeTag = doc.createElement(QString("name"));
QDomText text = doc.createTextNode(newName);
newNodeTag.appendChild(text);
root.replaceChild(newNodeTag, nodelist);
QDomElement e = doc.documentElement();
e.setAttribute("id", newName);
if (file.open(QFile::WriteOnly | QFile::Truncate)) {
QTextStream out(&file);
out << doc.toString();
}
file.close();
deleteEffect(index);
QString path = dir.absoluteFilePath(newName + QStringLiteral(".xml"));
return path;
}
else
{
QFile file(dir.absoluteFilePath(currentName + QStringLiteral(".xml")));
if (file.open(QFile::WriteOnly | QFile::Truncate)) {
QTextStream out(&file);
out << doc.toString();
}
file.close();
return oldpath;
}
}
QVariant AssetTreeModel::data(const QModelIndex &index, int role) const
{
if (!index.isValid()) {
......
......@@ -44,6 +44,7 @@ public:
QString getDescription(bool isEffect, const QModelIndex &index) const;
// Helper function to retrieve if an effect is categorized as favorite
bool isFavorite(const QModelIndex &index) const;
QString editCustomEffectInfo( const QString newName,const QString newDescription,const QModelIndex &index);
QHash<int, QByteArray> roleNames() const override;
QVariant data(const QModelIndex &index, int role) const override;
virtual void reloadAssetMenu(QMenu *effectsMenu, KActionCategory *effectActions) = 0;
......
......@@ -29,6 +29,11 @@
#include <QQuickItem>
#include <QStandardPaths>
#include <kdeclarative_version.h>
#include <QFormLayout>
#include <QDialog>
#include <QDialogButtonBox>
#include <QLineEdit>
#include <QTextEdit>
AssetListWidget::AssetListWidget(QWidget *parent)
: QQuickWidget(parent)
......@@ -84,6 +89,32 @@ QString AssetListWidget::getDescription(bool isEffect, const QModelIndex &index)
return m_model->getDescription(isEffect, m_proxyModel->mapToSource(index));
}
QString AssetListWidget::editCustomEffectInfo(const QModelIndex &index)
{
QDialog dialog(this);
QFormLayout form(&dialog);
QLineEdit *effectName = new QLineEdit(&dialog);
QTextEdit *descriptionBox = new QTextEdit(&dialog);
QString label_Name = QString("Name : ");
form.addRow(label_Name, effectName);
QString label = QString("Comments : ");
form.addRow(label, descriptionBox);
QDialogButtonBox buttonBox(QDialogButtonBox::Ok | QDialogButtonBox::Cancel, Qt::Horizontal, &dialog);
form.addRow(&buttonBox);
QObject::connect(&buttonBox, SIGNAL(accepted()), &dialog, SLOT(accept()));
QObject::connect(&buttonBox, SIGNAL(rejected()), &dialog, SLOT(reject()));
if(dialog.exec() == QDialog::Accepted) {
QString name = effectName->text();
QString enteredDescription = descriptionBox->toPlainText();
if (name.trimmed().isEmpty() && enteredDescription.trimmed().isEmpty()) {
return index.data().toString();
}
return m_model->editCustomEffectInfo(name, enteredDescription, m_proxyModel->mapToSource(index));
}
return index.data().toString();
}
void AssetListWidget::setFilterName(const QString &pattern)
{
m_proxyModel->setFilterName(!pattern.isEmpty(), pattern);
......
......@@ -55,7 +55,7 @@ public:
/* @brief Delete a custom effect */
void deleteCustomEffect(const QModelIndex &index);
virtual void reloadCustomEffectIx(const QModelIndex &index) = 0;
QString editCustomEffectInfo(const QModelIndex &index);
/* @brief Returns the description of the asset given its model index */
QString getDescription(bool isEffect, const QModelIndex &index) const;
......
......@@ -338,6 +338,14 @@ Rectangle {
assetlist.reloadCustomEffectIx(sel.currentIndex)
}
}
MenuItem {
id: editMenu
text: i18n("Edit Info")
visible: isEffectList && assetContextMenu.isCustom
onTriggered: {
assetlist.editCustomEffectInfo(sel.currentIndex)
}
}
}
TableViewColumn { role: "identifier"; title: i18n("Name"); }
......
......@@ -81,6 +81,14 @@ public:
}
Q_INVOKABLE void deleteCustomEffect(const QModelIndex &index) { q->deleteCustomEffect(index); }
Q_INVOKABLE QString getDescription(const QModelIndex &index) const { return q->getDescription(true, index); }
Q_INVOKABLE void editCustomEffectInfo(const QModelIndex &index)
{
QString pathToUpdate = q->editCustomEffectInfo(index);
if(index.data().toString() != pathToUpdate)
{
q->reloadCustomEffect(pathToUpdate);
}
}
Q_INVOKABLE QVariantMap getMimeData(const QString &assetId) const { return q->getMimeData(assetId); }
Q_INVOKABLE void activate(const QModelIndex &ix) { q->activate(ix); }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment