feat(ui): make selected mods in downloader bold with underline
Makes it easier to find which mods are selected in case you want to change those.
This commit is contained in:
parent
613f2fc447
commit
8f2c485c92
@ -134,6 +134,12 @@ bool ModDownloadDialog::isModSelected(const QString &name, const QString& filena
|
|||||||
return iter != modTask.end() && (iter.value()->getFilename() == filename);
|
return iter != modTask.end() && (iter.value()->getFilename() == filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool ModDownloadDialog::isModSelected(const QString &name) const
|
||||||
|
{
|
||||||
|
auto iter = modTask.find(name);
|
||||||
|
return iter != modTask.end();
|
||||||
|
}
|
||||||
|
|
||||||
ModDownloadDialog::~ModDownloadDialog()
|
ModDownloadDialog::~ModDownloadDialog()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -32,6 +32,7 @@ public:
|
|||||||
void addSelectedMod(const QString & name = QString(), ModDownloadTask * task = nullptr);
|
void addSelectedMod(const QString & name = QString(), ModDownloadTask * task = nullptr);
|
||||||
void removeSelectedMod(const QString & name = QString());
|
void removeSelectedMod(const QString & name = QString());
|
||||||
bool isModSelected(const QString & name, const QString & filename) const;
|
bool isModSelected(const QString & name, const QString & filename) const;
|
||||||
|
bool isModSelected(const QString & name) const;
|
||||||
|
|
||||||
const QList<ModDownloadTask*> getTasks();
|
const QList<ModDownloadTask*> getTasks();
|
||||||
const std::shared_ptr<ModFolderModel> &mods;
|
const std::shared_ptr<ModFolderModel> &mods;
|
||||||
@ -41,8 +42,6 @@ public slots:
|
|||||||
void accept() override;
|
void accept() override;
|
||||||
void reject() override;
|
void reject() override;
|
||||||
|
|
||||||
//private slots:
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Ui::ModDownloadDialog *ui = nullptr;
|
Ui::ModDownloadDialog *ui = nullptr;
|
||||||
PageContainer * m_container = nullptr;
|
PageContainer * m_container = nullptr;
|
||||||
|
@ -38,27 +38,44 @@ auto ListModel::data(const QModelIndex& index, int role) const -> QVariant
|
|||||||
}
|
}
|
||||||
|
|
||||||
ModPlatform::IndexedPack pack = modpacks.at(pos);
|
ModPlatform::IndexedPack pack = modpacks.at(pos);
|
||||||
if (role == Qt::DisplayRole) {
|
switch (role) {
|
||||||
return pack.name;
|
case Qt::DisplayRole: {
|
||||||
} else if (role == Qt::ToolTipRole) {
|
return pack.name;
|
||||||
if (pack.description.length() > 100) {
|
|
||||||
// some magic to prevent to long tooltips and replace html linebreaks
|
|
||||||
QString edit = pack.description.left(97);
|
|
||||||
edit = edit.left(edit.lastIndexOf("<br>")).left(edit.lastIndexOf(" ")).append("...");
|
|
||||||
return edit;
|
|
||||||
}
|
}
|
||||||
return pack.description;
|
case Qt::ToolTipRole: {
|
||||||
} else if (role == Qt::DecorationRole) {
|
if (pack.description.length() > 100) {
|
||||||
if (m_logoMap.contains(pack.logoName)) {
|
// some magic to prevent to long tooltips and replace html linebreaks
|
||||||
return (m_logoMap.value(pack.logoName));
|
QString edit = pack.description.left(97);
|
||||||
|
edit = edit.left(edit.lastIndexOf("<br>")).left(edit.lastIndexOf(" ")).append("...");
|
||||||
|
return edit;
|
||||||
|
}
|
||||||
|
return pack.description;
|
||||||
}
|
}
|
||||||
QIcon icon = APPLICATION->getThemedIcon("screenshot-placeholder");
|
case Qt::DecorationRole: {
|
||||||
((ListModel*)this)->requestLogo(pack.logoName, pack.logoUrl);
|
if (m_logoMap.contains(pack.logoName)) {
|
||||||
return icon;
|
return (m_logoMap.value(pack.logoName));
|
||||||
} else if (role == Qt::UserRole) {
|
}
|
||||||
QVariant v;
|
QIcon icon = APPLICATION->getThemedIcon("screenshot-placeholder");
|
||||||
v.setValue(pack);
|
// un-const-ify this
|
||||||
return v;
|
((ListModel*)this)->requestLogo(pack.logoName, pack.logoUrl);
|
||||||
|
return icon;
|
||||||
|
}
|
||||||
|
case Qt::UserRole: {
|
||||||
|
QVariant v;
|
||||||
|
v.setValue(pack);
|
||||||
|
return v;
|
||||||
|
}
|
||||||
|
case Qt::FontRole: {
|
||||||
|
QFont font;
|
||||||
|
if (m_parent->getDialog()->isModSelected(pack.name)) {
|
||||||
|
font.setBold(true);
|
||||||
|
font.setUnderline(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
return font;
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return {};
|
return {};
|
||||||
|
@ -41,6 +41,7 @@ class ModPage : public QWidget, public BasePage {
|
|||||||
|
|
||||||
auto apiProvider() const -> const ModAPI* { return api.get(); };
|
auto apiProvider() const -> const ModAPI* { return api.get(); };
|
||||||
auto getFilter() const -> const std::shared_ptr<ModFilterWidget::Filter> { return m_filter; }
|
auto getFilter() const -> const std::shared_ptr<ModFilterWidget::Filter> { return m_filter; }
|
||||||
|
auto getDialog() const -> const ModDownloadDialog* { return dialog; }
|
||||||
|
|
||||||
auto getCurrent() -> ModPlatform::IndexedPack& { return current; }
|
auto getCurrent() -> ModPlatform::IndexedPack& { return current; }
|
||||||
void updateModVersions(int prev_count = -1);
|
void updateModVersions(int prev_count = -1);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user