forked from eden-emu/eden
		
	Merge pull request #10006 from german77/profile_select
service: am: Improve profile select applet
This commit is contained in:
		
						commit
						1ab052952d
					
				
					 8 changed files with 270 additions and 34 deletions
				
			
		|  | @ -576,6 +576,10 @@ void GMainWindow::RegisterMetaTypes() { | |||
|     // Controller Applet
 | ||||
|     qRegisterMetaType<Core::Frontend::ControllerParameters>("Core::Frontend::ControllerParameters"); | ||||
| 
 | ||||
|     // Profile Select Applet
 | ||||
|     qRegisterMetaType<Core::Frontend::ProfileSelectParameters>( | ||||
|         "Core::Frontend::ProfileSelectParameters"); | ||||
| 
 | ||||
|     // Software Keyboard Applet
 | ||||
|     qRegisterMetaType<Core::Frontend::KeyboardInitializeParameters>( | ||||
|         "Core::Frontend::KeyboardInitializeParameters"); | ||||
|  | @ -652,8 +656,9 @@ void GMainWindow::ControllerSelectorRequestExit() { | |||
|     } | ||||
| } | ||||
| 
 | ||||
| void GMainWindow::ProfileSelectorSelectProfile() { | ||||
|     profile_select_applet = new QtProfileSelectionDialog(system->HIDCore(), this); | ||||
| void GMainWindow::ProfileSelectorSelectProfile( | ||||
|     const Core::Frontend::ProfileSelectParameters& parameters) { | ||||
|     profile_select_applet = new QtProfileSelectionDialog(system->HIDCore(), this, parameters); | ||||
|     SCOPE_EXIT({ | ||||
|         profile_select_applet->deleteLater(); | ||||
|         profile_select_applet = nullptr; | ||||
|  | @ -1720,8 +1725,9 @@ bool GMainWindow::LoadROM(const QString& filename, u64 program_id, std::size_t p | |||
|     return true; | ||||
| } | ||||
| 
 | ||||
| bool GMainWindow::SelectAndSetCurrentUser() { | ||||
|     QtProfileSelectionDialog dialog(system->HIDCore(), this); | ||||
| bool GMainWindow::SelectAndSetCurrentUser( | ||||
|     const Core::Frontend::ProfileSelectParameters& parameters) { | ||||
|     QtProfileSelectionDialog dialog(system->HIDCore(), this, parameters); | ||||
|     dialog.setWindowFlags(Qt::Dialog | Qt::CustomizeWindowHint | Qt::WindowTitleHint | | ||||
|                           Qt::WindowSystemMenuHint | Qt::WindowCloseButtonHint); | ||||
|     dialog.setWindowModality(Qt::WindowModal); | ||||
|  | @ -1767,7 +1773,13 @@ void GMainWindow::BootGame(const QString& filename, u64 program_id, std::size_t | |||
|     Settings::LogSettings(); | ||||
| 
 | ||||
|     if (UISettings::values.select_user_on_boot) { | ||||
|         if (SelectAndSetCurrentUser() == false) { | ||||
|         const Core::Frontend::ProfileSelectParameters parameters{ | ||||
|             .mode = Service::AM::Applets::UiMode::UserSelector, | ||||
|             .invalid_uid_list = {}, | ||||
|             .display_options = {}, | ||||
|             .purpose = Service::AM::Applets::UserSelectionPurpose::General, | ||||
|         }; | ||||
|         if (SelectAndSetCurrentUser(parameters) == false) { | ||||
|             return; | ||||
|         } | ||||
|     } | ||||
|  | @ -2059,7 +2071,13 @@ void GMainWindow::OnGameListOpenFolder(u64 program_id, GameListOpenTarget target | |||
|         if (has_user_save) { | ||||
|             // User save data
 | ||||
|             const auto select_profile = [this] { | ||||
|                 QtProfileSelectionDialog dialog(system->HIDCore(), this); | ||||
|                 const Core::Frontend::ProfileSelectParameters parameters{ | ||||
|                     .mode = Service::AM::Applets::UiMode::UserSelector, | ||||
|                     .invalid_uid_list = {}, | ||||
|                     .display_options = {}, | ||||
|                     .purpose = Service::AM::Applets::UserSelectionPurpose::General, | ||||
|                 }; | ||||
|                 QtProfileSelectionDialog dialog(system->HIDCore(), this, parameters); | ||||
|                 dialog.setWindowFlags(Qt::Dialog | Qt::CustomizeWindowHint | Qt::WindowTitleHint | | ||||
|                                       Qt::WindowSystemMenuHint | Qt::WindowCloseButtonHint); | ||||
|                 dialog.setWindowModality(Qt::WindowModal); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 liamwhite
						liamwhite