mirror of
https://github.com/PrismLauncher/PrismLauncher.git
synced 2026-06-29 01:54:20 +03:00
add category selector to icon picker dialog (#4397)
This commit is contained in:
commit
803115cfde
3 changed files with 165 additions and 9 deletions
|
|
@ -30,26 +30,106 @@
|
|||
#include "icons/IconList.h"
|
||||
#include "icons/IconUtils.h"
|
||||
|
||||
class IconProxyModel : public QSortFilterProxyModel
|
||||
{
|
||||
public:
|
||||
explicit IconProxyModel(QObject* parent = nullptr) : QSortFilterProxyModel(parent)
|
||||
{
|
||||
}
|
||||
|
||||
void setCategory(IconPickerDialog::IconPickerCategory category)
|
||||
{
|
||||
if (m_category == category)
|
||||
return;
|
||||
m_category = category;
|
||||
invalidateFilter();
|
||||
}
|
||||
|
||||
protected:
|
||||
bool filterAcceptsRow(int source_row, const QModelIndex& source_parent) const override
|
||||
{
|
||||
if (!QSortFilterProxyModel::filterAcceptsRow(source_row, source_parent))
|
||||
return false;
|
||||
|
||||
if (m_category == IconPickerDialog::Any)
|
||||
return true;
|
||||
|
||||
auto model = static_cast<IconList*>(sourceModel());
|
||||
QModelIndex index = model->index(source_row, 0, source_parent);
|
||||
QString key = model->data(index, Qt::UserRole).toString();
|
||||
const MMCIcon* icon = model->icon(key);
|
||||
|
||||
if (!icon)
|
||||
return false;
|
||||
|
||||
bool isModpack = false;
|
||||
bool isBuiltin = icon->isBuiltIn();
|
||||
bool isLegacy = isBuiltin && icon->name().endsWith("_legacy", Qt::CaseInsensitive);
|
||||
|
||||
if (!isBuiltin) {
|
||||
const QString& name = icon->name();
|
||||
if (name.startsWith("curseforge_", Qt::CaseInsensitive) ||
|
||||
name.startsWith("modrinth_", Qt::CaseInsensitive) ||
|
||||
name.startsWith("ftb_", Qt::CaseInsensitive) ||
|
||||
name.startsWith("technic_", Qt::CaseInsensitive) ||
|
||||
name.startsWith("atl_", Qt::CaseInsensitive)) {
|
||||
isModpack = true;
|
||||
}
|
||||
}
|
||||
|
||||
switch (m_category) {
|
||||
case IconPickerDialog::Legacy:
|
||||
return isBuiltin && isLegacy;
|
||||
case IconPickerDialog::Modpacks:
|
||||
return isModpack;
|
||||
case IconPickerDialog::Modern:
|
||||
return isBuiltin && !isLegacy;
|
||||
case IconPickerDialog::Custom:
|
||||
return !isBuiltin && !isModpack;
|
||||
default:
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
private:
|
||||
IconPickerDialog::IconPickerCategory m_category = IconPickerDialog::Any;
|
||||
};
|
||||
|
||||
IconPickerDialog::IconPickerDialog(QWidget* parent) : QDialog(parent), ui(new Ui::IconPickerDialog)
|
||||
{
|
||||
ui->setupUi(this);
|
||||
setWindowModality(Qt::WindowModal);
|
||||
|
||||
searchBar = new QLineEdit(this);
|
||||
searchBar->setPlaceholderText(tr("Search..."));
|
||||
ui->verticalLayout->insertWidget(0, searchBar);
|
||||
static const QString context_text[] = {
|
||||
tr("All"),
|
||||
tr("Modern"),
|
||||
tr("Legacy"),
|
||||
tr("Modpacks"),
|
||||
tr("Custom"),
|
||||
};
|
||||
static const IconPickerCategory context_id[] = {
|
||||
Any,
|
||||
Modern,
|
||||
Legacy,
|
||||
Modpacks,
|
||||
Custom,
|
||||
};
|
||||
const int cnt = sizeof(context_text) / sizeof(context_text[0]);
|
||||
for (int i = 0; i < cnt; ++i) {
|
||||
ui->contextCombo->addItem(context_text[i], context_id[i]);
|
||||
if (i == 0) {
|
||||
ui->contextCombo->insertSeparator(i + 1);
|
||||
}
|
||||
}
|
||||
|
||||
proxyModel = new QSortFilterProxyModel(this);
|
||||
proxyModel = new IconProxyModel(this);
|
||||
proxyModel->setSourceModel(APPLICATION->icons());
|
||||
proxyModel->setFilterCaseSensitivity(Qt::CaseInsensitive);
|
||||
ui->iconView->setModel(proxyModel);
|
||||
|
||||
auto contentsWidget = ui->iconView;
|
||||
contentsWidget->setViewMode(QListView::IconMode);
|
||||
contentsWidget->setFlow(QListView::LeftToRight);
|
||||
contentsWidget->setIconSize(QSize(48, 48));
|
||||
contentsWidget->setMovement(QListView::Static);
|
||||
contentsWidget->setResizeMode(QListView::Adjust);
|
||||
contentsWidget->setSelectionMode(QAbstractItemView::SingleSelection);
|
||||
contentsWidget->setSpacing(5);
|
||||
contentsWidget->setWordWrap(false);
|
||||
|
|
@ -86,7 +166,11 @@ IconPickerDialog::IconPickerDialog(QWidget* parent) : QDialog(parent), ui(new Ui
|
|||
|
||||
auto buttonFolder = ui->buttonBox->addButton(tr("Open Folder"), QDialogButtonBox::ResetRole);
|
||||
connect(buttonFolder, &QPushButton::clicked, this, &IconPickerDialog::openFolder);
|
||||
connect(searchBar, &QLineEdit::textChanged, this, &IconPickerDialog::filterIcons);
|
||||
connect(ui->searchLine, &QLineEdit::textChanged, this, &IconPickerDialog::filterIcons);
|
||||
connect(ui->contextCombo, &QComboBox::currentIndexChanged, this, [this](int index) {
|
||||
IconPickerCategory category = static_cast<IconPickerCategory>(ui->contextCombo->itemData(index).toInt());
|
||||
filterIconsByCategory(category);
|
||||
});
|
||||
// Prevent incorrect indices from e.g. filesystem changes
|
||||
connect(APPLICATION->icons(), &IconList::iconUpdated, this, [this]() { proxyModel->invalidate(); });
|
||||
}
|
||||
|
|
@ -182,3 +266,8 @@ void IconPickerDialog::filterIcons(const QString& query)
|
|||
{
|
||||
proxyModel->setFilterFixedString(query);
|
||||
}
|
||||
|
||||
void IconPickerDialog::filterIconsByCategory(IconPickerCategory category)
|
||||
{
|
||||
static_cast<IconProxyModel*>(proxyModel)->setCategory(category);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -32,6 +32,15 @@ class IconPickerDialog : public QDialog {
|
|||
int execWithSelection(QString selection);
|
||||
QString selectedIconKey;
|
||||
|
||||
enum IconPickerCategory {
|
||||
Any,
|
||||
Modern,
|
||||
Legacy,
|
||||
Modpacks,
|
||||
Custom,
|
||||
};
|
||||
Q_ENUM(IconPickerCategory)
|
||||
|
||||
protected:
|
||||
virtual bool eventFilter(QObject*, QEvent*);
|
||||
|
||||
|
|
@ -49,4 +58,5 @@ class IconPickerDialog : public QDialog {
|
|||
void removeSelectedIcon();
|
||||
void openFolder();
|
||||
void filterIcons(const QString& text);
|
||||
void filterIconsByCategory(IconPickerCategory);
|
||||
};
|
||||
|
|
|
|||
|
|
@ -15,7 +15,64 @@
|
|||
</property>
|
||||
<layout class="QVBoxLayout" name="verticalLayout">
|
||||
<item>
|
||||
<widget class="QListView" name="iconView"/>
|
||||
<layout class="QVBoxLayout" name="verticalLayout">
|
||||
<item>
|
||||
<layout class="QHBoxLayout" name="horizontalLayout">
|
||||
<item>
|
||||
<widget class="QComboBox" name="contextCombo">
|
||||
<property name="accessibleName">
|
||||
<string>Icon category</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item>
|
||||
<spacer name="horizontalSpacer">
|
||||
<property name="orientation">
|
||||
<enum>Qt::Horizontal</enum>
|
||||
</property>
|
||||
<property name="sizeHint" stdset="0">
|
||||
<size>
|
||||
<width>40</width>
|
||||
<height>20</height>
|
||||
</size>
|
||||
</property>
|
||||
</spacer>
|
||||
</item>
|
||||
<item>
|
||||
<widget class="QLineEdit" name="searchLine">
|
||||
<property name="placeholderText">
|
||||
<string>Search Icons...</string>
|
||||
</property>
|
||||
<property name="clearButtonEnabled">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</item>
|
||||
</layout>
|
||||
</item>
|
||||
<item>
|
||||
<widget class="QListView" name="iconView">
|
||||
<property name="iconSize">
|
||||
<size>
|
||||
<width>60</width>
|
||||
<height>60</height>
|
||||
</size>
|
||||
</property>
|
||||
<property name="movement">
|
||||
<enum>QListView::Static</enum>
|
||||
</property>
|
||||
<property name="resizeMode">
|
||||
<enum>QListView::Adjust</enum>
|
||||
</property>
|
||||
<property name="viewMode">
|
||||
<enum>QListView::IconMode</enum>
|
||||
</property>
|
||||
<property name="uniformItemSizes">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item>
|
||||
<widget class="QDialogButtonBox" name="buttonBox">
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue