Merge pull request #1530 from Trial97/metadata_delete
This commit is contained in:
commit
546d49e183
@ -132,17 +132,23 @@ auto Mod::destroy(QDir& index_dir, bool preserve_metadata, bool attempt_trash) -
|
|||||||
if (!preserve_metadata) {
|
if (!preserve_metadata) {
|
||||||
qDebug() << QString("Destroying metadata for '%1' on purpose").arg(name());
|
qDebug() << QString("Destroying metadata for '%1' on purpose").arg(name());
|
||||||
|
|
||||||
if (metadata()) {
|
destroyMetadata(index_dir);
|
||||||
Metadata::remove(index_dir, metadata()->slug);
|
|
||||||
} else {
|
|
||||||
auto n = name();
|
|
||||||
Metadata::remove(index_dir, n);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return Resource::destroy(attempt_trash);
|
return Resource::destroy(attempt_trash);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Mod::destroyMetadata(QDir& index_dir)
|
||||||
|
{
|
||||||
|
if (metadata()) {
|
||||||
|
Metadata::remove(index_dir, metadata()->slug);
|
||||||
|
} else {
|
||||||
|
auto n = name();
|
||||||
|
Metadata::remove(index_dir, n);
|
||||||
|
}
|
||||||
|
m_local_details.metadata = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
auto Mod::details() const -> const ModDetails&
|
auto Mod::details() const -> const ModDetails&
|
||||||
{
|
{
|
||||||
return m_local_details;
|
return m_local_details;
|
||||||
|
@ -93,6 +93,8 @@ class Mod : public Resource {
|
|||||||
|
|
||||||
// Delete all the files of this mod
|
// Delete all the files of this mod
|
||||||
auto destroy(QDir& index_dir, bool preserve_metadata = false, bool attempt_trash = true) -> bool;
|
auto destroy(QDir& index_dir, bool preserve_metadata = false, bool attempt_trash = true) -> bool;
|
||||||
|
// Delete the metadata only
|
||||||
|
void destroyMetadata(QDir& index_dir);
|
||||||
|
|
||||||
void finishResolvingWithDetails(ModDetails&& details);
|
void finishResolvingWithDetails(ModDetails&& details);
|
||||||
|
|
||||||
|
@ -233,6 +233,25 @@ bool ModFolderModel::deleteMods(const QModelIndexList& indexes)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool ModFolderModel::deleteModsMetadata(const QModelIndexList& indexes)
|
||||||
|
{
|
||||||
|
if (indexes.isEmpty())
|
||||||
|
return true;
|
||||||
|
|
||||||
|
for (auto i : indexes) {
|
||||||
|
if (i.column() != 0) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
auto m = at(i.row());
|
||||||
|
auto index_dir = indexDir();
|
||||||
|
m->destroyMetadata(index_dir);
|
||||||
|
}
|
||||||
|
|
||||||
|
update();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
bool ModFolderModel::isValid()
|
bool ModFolderModel::isValid()
|
||||||
{
|
{
|
||||||
return m_dir.exists() && m_dir.isReadable();
|
return m_dir.exists() && m_dir.isReadable();
|
||||||
|
@ -81,6 +81,7 @@ class ModFolderModel : public ResourceFolderModel {
|
|||||||
|
|
||||||
/// Deletes all the selected mods
|
/// Deletes all the selected mods
|
||||||
bool deleteMods(const QModelIndexList& indexes);
|
bool deleteMods(const QModelIndexList& indexes);
|
||||||
|
bool deleteModsMetadata(const QModelIndexList& indexes);
|
||||||
|
|
||||||
bool isValid();
|
bool isValid();
|
||||||
|
|
||||||
|
@ -168,6 +168,17 @@
|
|||||||
<string>Go to mods home page</string>
|
<string>Go to mods home page</string>
|
||||||
</property>
|
</property>
|
||||||
</action>
|
</action>
|
||||||
|
<action name="actionRemoveItemMetadata">
|
||||||
|
<property name="enabled">
|
||||||
|
<bool>false</bool>
|
||||||
|
</property>
|
||||||
|
<property name="text">
|
||||||
|
<string>Remove metadata</string>
|
||||||
|
</property>
|
||||||
|
<property name="toolTip">
|
||||||
|
<string>Remove mod's metadata</string>
|
||||||
|
</property>
|
||||||
|
</action>
|
||||||
</widget>
|
</widget>
|
||||||
<customwidgets>
|
<customwidgets>
|
||||||
<customwidget>
|
<customwidget>
|
||||||
|
@ -92,6 +92,10 @@ ModFolderPage::ModFolderPage(BaseInstance* inst, std::shared_ptr<ModFolderModel>
|
|||||||
ui->actionsToolbar->addAction(ui->actionVisitItemPage);
|
ui->actionsToolbar->addAction(ui->actionVisitItemPage);
|
||||||
connect(ui->actionVisitItemPage, &QAction::triggered, this, &ModFolderPage::visitModPages);
|
connect(ui->actionVisitItemPage, &QAction::triggered, this, &ModFolderPage::visitModPages);
|
||||||
|
|
||||||
|
ui->actionRemoveItemMetadata->setToolTip(tr("Remove mod's metadata"));
|
||||||
|
ui->actionsToolbar->insertActionAfter(ui->actionRemoveItem, ui->actionRemoveItemMetadata);
|
||||||
|
connect(ui->actionRemoveItemMetadata, &QAction::triggered, this, &ModFolderPage::deleteModMetadata);
|
||||||
|
|
||||||
auto check_allow_update = [this] { return ui->treeView->selectionModel()->hasSelection() || !m_model->empty(); };
|
auto check_allow_update = [this] { return ui->treeView->selectionModel()->hasSelection() || !m_model->empty(); };
|
||||||
|
|
||||||
connect(ui->treeView->selectionModel(), &QItemSelectionModel::selectionChanged, this, [this, check_allow_update] {
|
connect(ui->treeView->selectionModel(), &QItemSelectionModel::selectionChanged, this, [this, check_allow_update] {
|
||||||
@ -104,11 +108,16 @@ ModFolderPage::ModFolderPage(BaseInstance* inst, std::shared_ptr<ModFolderModel>
|
|||||||
if (selected <= 1) {
|
if (selected <= 1) {
|
||||||
ui->actionVisitItemPage->setText(tr("Visit mod's page"));
|
ui->actionVisitItemPage->setText(tr("Visit mod's page"));
|
||||||
ui->actionVisitItemPage->setToolTip(tr("Go to mod's home page"));
|
ui->actionVisitItemPage->setToolTip(tr("Go to mod's home page"));
|
||||||
|
|
||||||
|
ui->actionRemoveItemMetadata->setToolTip(tr("Remove mod's metadata"));
|
||||||
} else {
|
} else {
|
||||||
ui->actionVisitItemPage->setText(tr("Visit mods' pages"));
|
ui->actionVisitItemPage->setText(tr("Visit mods' pages"));
|
||||||
ui->actionVisitItemPage->setToolTip(tr("Go to the pages of the selected mods"));
|
ui->actionVisitItemPage->setToolTip(tr("Go to the pages of the selected mods"));
|
||||||
|
|
||||||
|
ui->actionRemoveItemMetadata->setToolTip(tr("Remove mods' metadata"));
|
||||||
}
|
}
|
||||||
ui->actionVisitItemPage->setEnabled(selected != 0);
|
ui->actionVisitItemPage->setEnabled(selected != 0);
|
||||||
|
ui->actionRemoveItemMetadata->setEnabled(selected != 0);
|
||||||
});
|
});
|
||||||
|
|
||||||
connect(mods.get(), &ModFolderModel::rowsInserted, this,
|
connect(mods.get(), &ModFolderModel::rowsInserted, this,
|
||||||
@ -297,3 +306,24 @@ void ModFolderPage::visitModPages()
|
|||||||
DesktopServices::openUrl(url);
|
DesktopServices::openUrl(url);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ModFolderPage::deleteModMetadata()
|
||||||
|
{
|
||||||
|
auto selection = m_filterModel->mapSelectionToSource(ui->treeView->selectionModel()->selection()).indexes();
|
||||||
|
auto selectionCount = m_model->selectedMods(selection).length();
|
||||||
|
if (selectionCount == 0)
|
||||||
|
return;
|
||||||
|
if (selectionCount > 1) {
|
||||||
|
auto response = CustomMessageBox::selectable(this, tr("Confirm Removal"),
|
||||||
|
tr("You are about to remove the metadata for %1 mods.\n"
|
||||||
|
"Are you sure?")
|
||||||
|
.arg(selectionCount),
|
||||||
|
QMessageBox::Warning, QMessageBox::Yes | QMessageBox::No, QMessageBox::No)
|
||||||
|
->exec();
|
||||||
|
|
||||||
|
if (response != QMessageBox::Yes)
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_model->deleteModsMetadata(selection);
|
||||||
|
}
|
||||||
|
@ -61,6 +61,7 @@ class ModFolderPage : public ExternalResourcesPage {
|
|||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void removeItems(const QItemSelection& selection) override;
|
void removeItems(const QItemSelection& selection) override;
|
||||||
|
void deleteModMetadata();
|
||||||
|
|
||||||
void installMods();
|
void installMods();
|
||||||
void updateMods();
|
void updateMods();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user