forked from eden-emu/eden
		
	Qt/Configure: Use sidebar to divide tabs into smaller groups
This commit is contained in:
		
							parent
							
								
									7961e11cd4
								
							
						
					
					
						commit
						8a5f6de6c8
					
				
					 3 changed files with 124 additions and 59 deletions
				
			
		|  | @ -6,14 +6,32 @@ | ||||||
|    <rect> |    <rect> | ||||||
|     <x>0</x> |     <x>0</x> | ||||||
|     <y>0</y> |     <y>0</y> | ||||||
|     <width>461</width> |     <width>382</width> | ||||||
|     <height>659</height> |     <height>241</height> | ||||||
|    </rect> |    </rect> | ||||||
|   </property> |   </property> | ||||||
|   <property name="windowTitle"> |   <property name="windowTitle"> | ||||||
|    <string>yuzu Configuration</string> |    <string>yuzu Configuration</string> | ||||||
|   </property> |   </property> | ||||||
|   <layout class="QVBoxLayout" name="verticalLayout"> |   <layout class="QVBoxLayout" name="verticalLayout"> | ||||||
|  |    <item> | ||||||
|  |     <layout class="QHBoxLayout" name="horizontalLayout"> | ||||||
|  |      <item> | ||||||
|  |       <widget class="QListWidget" name="selectorList"> | ||||||
|  |        <property name="minimumSize"> | ||||||
|  |         <size> | ||||||
|  |          <width>150</width> | ||||||
|  |          <height>0</height> | ||||||
|  |         </size> | ||||||
|  |        </property> | ||||||
|  |        <property name="maximumSize"> | ||||||
|  |         <size> | ||||||
|  |          <width>150</width> | ||||||
|  |          <height>16777215</height> | ||||||
|  |         </size> | ||||||
|  |        </property> | ||||||
|  |       </widget> | ||||||
|  |      </item> | ||||||
|      <item> |      <item> | ||||||
|       <widget class="QTabWidget" name="tabWidget"> |       <widget class="QTabWidget" name="tabWidget"> | ||||||
|        <property name="currentIndex"> |        <property name="currentIndex"> | ||||||
|  | @ -61,6 +79,8 @@ | ||||||
|        </widget> |        </widget> | ||||||
|       </widget> |       </widget> | ||||||
|      </item> |      </item> | ||||||
|  |     </layout> | ||||||
|  |    </item> | ||||||
|    <item> |    <item> | ||||||
|     <widget class="QDialogButtonBox" name="buttonBox"> |     <widget class="QDialogButtonBox" name="buttonBox"> | ||||||
|      <property name="standardButtons"> |      <property name="standardButtons"> | ||||||
|  | @ -77,12 +97,6 @@ | ||||||
|    <header>configuration/configure_general.h</header> |    <header>configuration/configure_general.h</header> | ||||||
|    <container>1</container> |    <container>1</container> | ||||||
|   </customwidget> |   </customwidget> | ||||||
|   <customwidget> |  | ||||||
|    <class>ConfigureGameList</class> |  | ||||||
|    <extends>QWidget</extends> |  | ||||||
|    <header>configuration/configure_gamelist.h</header> |  | ||||||
|    <container>1</container> |  | ||||||
|   </customwidget> |  | ||||||
|   <customwidget> |   <customwidget> | ||||||
|    <class>ConfigureSystem</class> |    <class>ConfigureSystem</class> | ||||||
|    <extends>QWidget</extends> |    <extends>QWidget</extends> | ||||||
|  | @ -101,12 +115,6 @@ | ||||||
|    <header>configuration/configure_debug.h</header> |    <header>configuration/configure_debug.h</header> | ||||||
|    <container>1</container> |    <container>1</container> | ||||||
|   </customwidget> |   </customwidget> | ||||||
|   <customwidget> |  | ||||||
|    <class>ConfigureInputSimple</class> |  | ||||||
|    <extends>QWidget</extends> |  | ||||||
|    <header>configuration/configure_input_simple.h</header> |  | ||||||
|    <container>1</container> |  | ||||||
|   </customwidget> |  | ||||||
|   <customwidget> |   <customwidget> | ||||||
|    <class>ConfigureGraphics</class> |    <class>ConfigureGraphics</class> | ||||||
|    <extends>QWidget</extends> |    <extends>QWidget</extends> | ||||||
|  | @ -119,6 +127,18 @@ | ||||||
|    <header>configuration/configure_web.h</header> |    <header>configuration/configure_web.h</header> | ||||||
|    <container>1</container> |    <container>1</container> | ||||||
|   </customwidget> |   </customwidget> | ||||||
|  |   <customwidget> | ||||||
|  |    <class>ConfigureGameList</class> | ||||||
|  |    <extends>QWidget</extends> | ||||||
|  |    <header>configuration/configure_gamelist.h</header> | ||||||
|  |    <container>1</container> | ||||||
|  |   </customwidget> | ||||||
|  |   <customwidget> | ||||||
|  |    <class>ConfigureInputSimple</class> | ||||||
|  |    <extends>QWidget</extends> | ||||||
|  |    <header>configuration/configure_input_simple.h</header> | ||||||
|  |    <container>1</container> | ||||||
|  |   </customwidget> | ||||||
|  </customwidgets> |  </customwidgets> | ||||||
|  <resources/> |  <resources/> | ||||||
|  <connections> |  <connections> | ||||||
|  |  | ||||||
|  | @ -2,6 +2,8 @@ | ||||||
| // Licensed under GPLv2 or any later version
 | // Licensed under GPLv2 or any later version
 | ||||||
| // Refer to the license.txt file included.
 | // Refer to the license.txt file included.
 | ||||||
| 
 | 
 | ||||||
|  | #include <QHash> | ||||||
|  | #include <QListWidgetItem> | ||||||
| #include "core/settings.h" | #include "core/settings.h" | ||||||
| #include "ui_configure.h" | #include "ui_configure.h" | ||||||
| #include "yuzu/configuration/config.h" | #include "yuzu/configuration/config.h" | ||||||
|  | @ -13,6 +15,13 @@ ConfigureDialog::ConfigureDialog(QWidget* parent, const HotkeyRegistry& registry | ||||||
|     ui->setupUi(this); |     ui->setupUi(this); | ||||||
|     ui->generalTab->PopulateHotkeyList(registry); |     ui->generalTab->PopulateHotkeyList(registry); | ||||||
|     this->setConfiguration(); |     this->setConfiguration(); | ||||||
|  |     this->PopulateSelectionList(); | ||||||
|  |     connect(ui->selectorList, &QListWidget::itemSelectionChanged, this, | ||||||
|  |             &ConfigureDialog::UpdateVisibleTabs); | ||||||
|  | 
 | ||||||
|  |     adjustSize(); | ||||||
|  | 
 | ||||||
|  |     ui->selectorList->setCurrentRow(0); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ConfigureDialog::~ConfigureDialog() = default; | ConfigureDialog::~ConfigureDialog() = default; | ||||||
|  | @ -30,3 +39,37 @@ void ConfigureDialog::applyConfiguration() { | ||||||
|     ui->webTab->applyConfiguration(); |     ui->webTab->applyConfiguration(); | ||||||
|     Settings::Apply(); |     Settings::Apply(); | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | void ConfigureDialog::PopulateSelectionList() { | ||||||
|  |     const std::array<std::pair<QString, QStringList>, 4> items{ | ||||||
|  |         {{tr("General"), {tr("General"), tr("Web"), tr("Debug"), tr("Game List")}}, | ||||||
|  |          {tr("System"), {tr("System"), tr("Audio")}}, | ||||||
|  |          {tr("Graphics"), {tr("Graphics")}}, | ||||||
|  |          {tr("Controls"), {tr("Input")}}}}; | ||||||
|  | 
 | ||||||
|  |     for (const auto& entry : items) { | ||||||
|  |         auto* const item = new QListWidgetItem(entry.first); | ||||||
|  |         item->setData(Qt::UserRole, entry.second); | ||||||
|  | 
 | ||||||
|  |         ui->selectorList->addItem(item); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void ConfigureDialog::UpdateVisibleTabs() { | ||||||
|  |     const auto items = ui->selectorList->selectedItems(); | ||||||
|  |     if (items.isEmpty()) | ||||||
|  |         return; | ||||||
|  | 
 | ||||||
|  |     const std::map<QString, QWidget*> widgets = { | ||||||
|  |         {tr("General"), ui->generalTab}, {tr("System"), ui->systemTab}, | ||||||
|  |         {tr("Input"), ui->inputTab},     {tr("Graphics"), ui->graphicsTab}, | ||||||
|  |         {tr("Audio"), ui->audioTab},     {tr("Debug"), ui->debugTab}, | ||||||
|  |         {tr("Web"), ui->webTab},         {tr("Game List"), ui->gameListTab}}; | ||||||
|  | 
 | ||||||
|  |     ui->tabWidget->clear(); | ||||||
|  | 
 | ||||||
|  |     const QStringList tabs = items[0]->data(Qt::UserRole).toStringList(); | ||||||
|  | 
 | ||||||
|  |     for (const auto& tab : tabs) | ||||||
|  |         ui->tabWidget->addTab(widgets.find(tab)->second, tab); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @ -24,6 +24,8 @@ public: | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     void setConfiguration(); |     void setConfiguration(); | ||||||
|  |     void UpdateVisibleTabs(); | ||||||
|  |     void PopulateSelectionList(); | ||||||
| 
 | 
 | ||||||
|     std::unique_ptr<Ui::ConfigureDialog> ui; |     std::unique_ptr<Ui::ConfigureDialog> ui; | ||||||
| }; | }; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 spycrab
						spycrab