From 3708c19324943f54a6ae3687f891114fc1ae9f54 Mon Sep 17 00:00:00 2001 From: Thomas Hartmann Date: Fri, 17 Feb 2023 18:30:25 +0100 Subject: StudioWelcome: Open design mode if project is opened again If an already opened project is opened again we swtich to design mode instead of edit mode and showing an error message. (cherry picked from commit 68a6b12b5a2ad4760d00048099c7e366df1649d2) Task-number: QDS-9183 Change-Id: I291e32a9824103a8f14f4fd618cc9211408ff2da Reviewed-by: Thomas Hartmann --- src/plugins/studiowelcome/studiowelcomeplugin.cpp | 26 +++++++++++++++++++++-- 1 file changed, 24 insertions(+), 2 deletions(-) diff --git a/src/plugins/studiowelcome/studiowelcomeplugin.cpp b/src/plugins/studiowelcome/studiowelcomeplugin.cpp index 677113221df..62af8cb96a4 100644 --- a/src/plugins/studiowelcome/studiowelcomeplugin.cpp +++ b/src/plugins/studiowelcome/studiowelcomeplugin.cpp @@ -4,6 +4,7 @@ #include "studiowelcomeplugin.h" #include "examplecheckout.h" +#include "projectexplorer/target.h" #include "qdsnewdialog.h" #include @@ -97,6 +98,20 @@ QPointer s_viewWindow = nullptr; QPointer s_viewWidget = nullptr; static StudioWelcomePlugin *s_pluginInstance = nullptr; +static Utils::FilePath getMainUiFile() +{ + auto project = ProjectExplorer::SessionManager::startupProject(); + if (!project) + return {}; + + if (!project->activeTarget()) + return {}; + + auto qmlBuildSystem = qobject_cast( + project->activeTarget()->buildSystem()); + return qmlBuildSystem->mainUiFilePath(); +} + std::unique_ptr makeUserFeedbackSettings() { QStringList domain = QCoreApplication::organizationDomain().split(QLatin1Char('.')); @@ -224,8 +239,15 @@ public: m_blockOpenRecent = true; const FilePath projectFile = FilePath::fromVariant(data(index(row, 0), ProjectModel::FilePathRole)); - if (projectFile.exists()) - ProjectExplorer::ProjectExplorerPlugin::openProjectWelcomePage(projectFile); + if (projectFile.exists()) { + const ProjectExplorerPlugin::OpenProjectResult result + = ProjectExplorer::ProjectExplorerPlugin::openProject(projectFile); + if (!result && !result.alreadyOpen().isEmpty()) { + const auto mainUiFile = getMainUiFile(); + if (mainUiFile.exists()) + Core::EditorManager::openEditor(mainUiFile, Utils::Id()); + }; + } resetProjects(); } -- cgit v1.2.3