CurseForge modpack page improvements
Signed-off-by: forkiesassds <icanttellyou@memeware.net>
This commit is contained in:
		| @@ -1,6 +1,7 @@ | ||||
| #include "FlameModel.h" | ||||
| #include <Json.h> | ||||
| #include "Application.h" | ||||
| #include "ui/widgets/ProjectItem.h" | ||||
|  | ||||
| #include <MMCStrings.h> | ||||
| #include <Version.h> | ||||
| @@ -31,29 +32,38 @@ QVariant ListModel::data(const QModelIndex& index, int role) const | ||||
|     } | ||||
|  | ||||
|     IndexedPack pack = modpacks.at(pos); | ||||
|     if (role == Qt::DisplayRole) { | ||||
|         return pack.name; | ||||
|     } else if (role == Qt::ToolTipRole) { | ||||
|         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; | ||||
|     switch (role) { | ||||
|         case Qt::ToolTipRole: { | ||||
|             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::DecorationRole: { | ||||
|             if (m_logoMap.contains(pack.logoName)) { | ||||
|                 return (m_logoMap.value(pack.logoName)); | ||||
|             } | ||||
|             QIcon icon = APPLICATION->getThemedIcon("screenshot-placeholder"); | ||||
|             ((ListModel*)this)->requestLogo(pack.logoName, pack.logoUrl); | ||||
|             return icon; | ||||
|         } case Qt::UserRole: { | ||||
|             QVariant v; | ||||
|             v.setValue(pack); | ||||
|             return v; | ||||
|         } | ||||
|         return pack.description; | ||||
|     } else if (role == Qt::DecorationRole) { | ||||
|         if (m_logoMap.contains(pack.logoName)) { | ||||
|             return (m_logoMap.value(pack.logoName)); | ||||
|         } | ||||
|         QIcon icon = APPLICATION->getThemedIcon("screenshot-placeholder"); | ||||
|         ((ListModel*)this)->requestLogo(pack.logoName, pack.logoUrl); | ||||
|         return icon; | ||||
|     } else if (role == Qt::UserRole) { | ||||
|         QVariant v; | ||||
|         v.setValue(pack); | ||||
|         return v; | ||||
|         case Qt::SizeHintRole: | ||||
|             return QSize(0, 58); | ||||
|         case UserDataTypes::TITLE: | ||||
|             return pack.name; | ||||
|         case UserDataTypes::DESCRIPTION: | ||||
|             return pack.description; | ||||
|         case UserDataTypes::SELECTED: | ||||
|             return false; | ||||
|         default: | ||||
|             break; | ||||
|     } | ||||
|  | ||||
|     return QVariant(); | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -43,6 +43,10 @@ | ||||
| #include "InstanceImportTask.h" | ||||
| #include "Json.h" | ||||
| #include "ui/dialogs/NewInstanceDialog.h" | ||||
| #include "ui/widgets/ProjectItem.h" | ||||
| #include "modplatform/flame/FlameAPI.h" | ||||
|  | ||||
| static FlameAPI api; | ||||
|  | ||||
| FlamePage::FlamePage(NewInstanceDialog* dialog, QWidget* parent) : QWidget(parent), ui(new Ui::FlamePage), dialog(dialog) | ||||
| { | ||||
| @@ -66,6 +70,9 @@ FlamePage::FlamePage(NewInstanceDialog* dialog, QWidget* parent) : QWidget(paren | ||||
|     connect(ui->sortByBox, SIGNAL(currentIndexChanged(int)), this, SLOT(triggerSearch())); | ||||
|     connect(ui->packView->selectionModel(), &QItemSelectionModel::currentChanged, this, &FlamePage::onSelectionChanged); | ||||
|     connect(ui->versionSelectionBox, &QComboBox::currentTextChanged, this, &FlamePage::onVersionSelectionChanged); | ||||
|  | ||||
|     ui->packView->setItemDelegate(new ProjectItemDelegate(this)); | ||||
|     ui->packDescription->setMetaEntry("FlamePacks"); | ||||
| } | ||||
|  | ||||
| FlamePage::~FlamePage() | ||||
| @@ -250,7 +257,10 @@ void FlamePage::updateUi() | ||||
|             text += "- " + tr("Source code: <a href=%1>%1</a>").arg(current.extra.sourceUrl) + "<br>"; | ||||
|     } | ||||
|  | ||||
|  | ||||
|     text += "<hr>"; | ||||
|     text += api.getModDescription(current.addonId).toUtf8(); | ||||
|  | ||||
|     ui->packDescription->setHtml(text + current.description); | ||||
|     ui->packDescription->flush(); | ||||
| } | ||||
|   | ||||
| @@ -66,7 +66,7 @@ | ||||
|       </widget> | ||||
|      </item> | ||||
|      <item> | ||||
|       <widget class="QTextBrowser" name="packDescription"> | ||||
|       <widget class="ProjectDescriptionPage" name="packDescription"> | ||||
|        <property name="openExternalLinks"> | ||||
|         <bool>true</bool> | ||||
|        </property> | ||||
| @@ -99,6 +99,13 @@ | ||||
|    </item> | ||||
|   </layout> | ||||
|  </widget> | ||||
|  <customwidgets> | ||||
|   <customwidget> | ||||
|    <class>ProjectDescriptionPage</class> | ||||
|    <extends>QTextBrowser</extends> | ||||
|    <header>ui/widgets/ProjectDescriptionPage.h</header> | ||||
|   </customwidget> | ||||
|  </customwidgets> | ||||
|  <tabstops> | ||||
|   <tabstop>packView</tabstop> | ||||
|   <tabstop>packDescription</tabstop> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 forkiesassds
					forkiesassds