mirror of
https://git.suyu.dev/suyu/suyu.git
synced 2025-01-05 07:10:59 +01:00
applets/web: Implement the online web browser applet
This commit is contained in:
parent
51cddcb8b8
commit
82fa9f8d56
8 changed files with 167 additions and 64 deletions
|
@ -20,4 +20,13 @@ void DefaultWebBrowserApplet::OpenLocalWebPage(
|
||||||
callback(Service::AM::Applets::WebExitReason::WindowClosed, "http://localhost/");
|
callback(Service::AM::Applets::WebExitReason::WindowClosed, "http://localhost/");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DefaultWebBrowserApplet::OpenExternalWebPage(
|
||||||
|
std::string_view external_url,
|
||||||
|
std::function<void(Service::AM::Applets::WebExitReason, std::string)> callback) const {
|
||||||
|
LOG_WARNING(Service_AM, "(STUBBED) called, backend requested to open external web page at {}",
|
||||||
|
external_url);
|
||||||
|
|
||||||
|
callback(Service::AM::Applets::WebExitReason::WindowClosed, "http://localhost/");
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace Core::Frontend
|
} // namespace Core::Frontend
|
||||||
|
|
|
@ -18,6 +18,10 @@ public:
|
||||||
virtual void OpenLocalWebPage(
|
virtual void OpenLocalWebPage(
|
||||||
std::string_view local_url, std::function<void()> extract_romfs_callback,
|
std::string_view local_url, std::function<void()> extract_romfs_callback,
|
||||||
std::function<void(Service::AM::Applets::WebExitReason, std::string)> callback) const = 0;
|
std::function<void(Service::AM::Applets::WebExitReason, std::string)> callback) const = 0;
|
||||||
|
|
||||||
|
virtual void OpenExternalWebPage(
|
||||||
|
std::string_view external_url,
|
||||||
|
std::function<void(Service::AM::Applets::WebExitReason, std::string)> callback) const = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
class DefaultWebBrowserApplet final : public WebBrowserApplet {
|
class DefaultWebBrowserApplet final : public WebBrowserApplet {
|
||||||
|
@ -27,6 +31,10 @@ public:
|
||||||
void OpenLocalWebPage(std::string_view local_url, std::function<void()> extract_romfs_callback,
|
void OpenLocalWebPage(std::string_view local_url, std::function<void()> extract_romfs_callback,
|
||||||
std::function<void(Service::AM::Applets::WebExitReason, std::string)>
|
std::function<void(Service::AM::Applets::WebExitReason, std::string)>
|
||||||
callback) const override;
|
callback) const override;
|
||||||
|
|
||||||
|
void OpenExternalWebPage(std::string_view external_url,
|
||||||
|
std::function<void(Service::AM::Applets::WebExitReason, std::string)>
|
||||||
|
callback) const override;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace Core::Frontend
|
} // namespace Core::Frontend
|
||||||
|
|
|
@ -409,7 +409,9 @@ void WebBrowser::InitializeOffline() {
|
||||||
|
|
||||||
void WebBrowser::InitializeShare() {}
|
void WebBrowser::InitializeShare() {}
|
||||||
|
|
||||||
void WebBrowser::InitializeWeb() {}
|
void WebBrowser::InitializeWeb() {
|
||||||
|
external_url = ParseStringValue(GetInputTLVData(WebArgInputTLVType::InitialURL).value());
|
||||||
|
}
|
||||||
|
|
||||||
void WebBrowser::InitializeWifi() {}
|
void WebBrowser::InitializeWifi() {}
|
||||||
|
|
||||||
|
@ -456,8 +458,12 @@ void WebBrowser::ExecuteShare() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebBrowser::ExecuteWeb() {
|
void WebBrowser::ExecuteWeb() {
|
||||||
LOG_WARNING(Service_AM, "(STUBBED) called, Web Applet is not implemented");
|
LOG_INFO(Service_AM, "Opening external URL at {}", external_url);
|
||||||
WebBrowserExit(WebExitReason::EndButtonPressed);
|
|
||||||
|
frontend.OpenExternalWebPage(external_url,
|
||||||
|
[this](WebExitReason exit_reason, std::string last_url) {
|
||||||
|
WebBrowserExit(exit_reason, last_url);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebBrowser::ExecuteWifi() {
|
void WebBrowser::ExecuteWifi() {
|
||||||
|
|
|
@ -79,6 +79,8 @@ private:
|
||||||
std::string offline_document;
|
std::string offline_document;
|
||||||
FileSys::VirtualFile offline_romfs;
|
FileSys::VirtualFile offline_romfs;
|
||||||
|
|
||||||
|
std::string external_url;
|
||||||
|
|
||||||
Core::System& system;
|
Core::System& system;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -51,59 +51,32 @@ QtNXWebEngineView::QtNXWebEngineView(QWidget* parent, Core::System& system,
|
||||||
InputCommon::InputSubsystem* input_subsystem_)
|
InputCommon::InputSubsystem* input_subsystem_)
|
||||||
: QWebEngineView(parent), input_subsystem{input_subsystem_},
|
: QWebEngineView(parent), input_subsystem{input_subsystem_},
|
||||||
url_interceptor(std::make_unique<UrlRequestInterceptor>()),
|
url_interceptor(std::make_unique<UrlRequestInterceptor>()),
|
||||||
input_interpreter(std::make_unique<InputInterpreter>(system)) {
|
input_interpreter(std::make_unique<InputInterpreter>(system)),
|
||||||
QWebEngineScript nx_font_css;
|
default_profile{QWebEngineProfile::defaultProfile()},
|
||||||
QWebEngineScript load_nx_font;
|
global_settings{QWebEngineSettings::globalSettings()} {
|
||||||
QWebEngineScript gamepad;
|
QWebEngineScript gamepad;
|
||||||
QWebEngineScript window_nx;
|
QWebEngineScript window_nx;
|
||||||
|
|
||||||
const QString fonts_dir = QString::fromStdString(Common::FS::SanitizePath(
|
|
||||||
fmt::format("{}/fonts", Common::FS::GetUserPath(Common::FS::UserPath::CacheDir))));
|
|
||||||
|
|
||||||
nx_font_css.setName(QStringLiteral("nx_font_css.js"));
|
|
||||||
load_nx_font.setName(QStringLiteral("load_nx_font.js"));
|
|
||||||
gamepad.setName(QStringLiteral("gamepad_script.js"));
|
gamepad.setName(QStringLiteral("gamepad_script.js"));
|
||||||
window_nx.setName(QStringLiteral("window_nx_script.js"));
|
window_nx.setName(QStringLiteral("window_nx_script.js"));
|
||||||
|
|
||||||
nx_font_css.setSourceCode(
|
|
||||||
QString::fromStdString(NX_FONT_CSS)
|
|
||||||
.arg(fonts_dir + QStringLiteral("/FontStandard.ttf"))
|
|
||||||
.arg(fonts_dir + QStringLiteral("/FontChineseSimplified.ttf"))
|
|
||||||
.arg(fonts_dir + QStringLiteral("/FontExtendedChineseSimplified.ttf"))
|
|
||||||
.arg(fonts_dir + QStringLiteral("/FontChineseTraditional.ttf"))
|
|
||||||
.arg(fonts_dir + QStringLiteral("/FontKorean.ttf"))
|
|
||||||
.arg(fonts_dir + QStringLiteral("/FontNintendoExtended.ttf"))
|
|
||||||
.arg(fonts_dir + QStringLiteral("/FontNintendoExtended2.ttf")));
|
|
||||||
load_nx_font.setSourceCode(QString::fromStdString(LOAD_NX_FONT));
|
|
||||||
gamepad.setSourceCode(QString::fromStdString(GAMEPAD_SCRIPT));
|
gamepad.setSourceCode(QString::fromStdString(GAMEPAD_SCRIPT));
|
||||||
window_nx.setSourceCode(QString::fromStdString(WINDOW_NX_SCRIPT));
|
window_nx.setSourceCode(QString::fromStdString(WINDOW_NX_SCRIPT));
|
||||||
|
|
||||||
nx_font_css.setInjectionPoint(QWebEngineScript::DocumentReady);
|
|
||||||
load_nx_font.setInjectionPoint(QWebEngineScript::Deferred);
|
|
||||||
gamepad.setInjectionPoint(QWebEngineScript::DocumentCreation);
|
gamepad.setInjectionPoint(QWebEngineScript::DocumentCreation);
|
||||||
window_nx.setInjectionPoint(QWebEngineScript::DocumentCreation);
|
window_nx.setInjectionPoint(QWebEngineScript::DocumentCreation);
|
||||||
|
|
||||||
nx_font_css.setWorldId(QWebEngineScript::MainWorld);
|
|
||||||
load_nx_font.setWorldId(QWebEngineScript::MainWorld);
|
|
||||||
gamepad.setWorldId(QWebEngineScript::MainWorld);
|
gamepad.setWorldId(QWebEngineScript::MainWorld);
|
||||||
window_nx.setWorldId(QWebEngineScript::MainWorld);
|
window_nx.setWorldId(QWebEngineScript::MainWorld);
|
||||||
|
|
||||||
nx_font_css.setRunsOnSubFrames(true);
|
|
||||||
load_nx_font.setRunsOnSubFrames(true);
|
|
||||||
gamepad.setRunsOnSubFrames(true);
|
gamepad.setRunsOnSubFrames(true);
|
||||||
window_nx.setRunsOnSubFrames(true);
|
window_nx.setRunsOnSubFrames(true);
|
||||||
|
|
||||||
auto* default_profile = QWebEngineProfile::defaultProfile();
|
|
||||||
|
|
||||||
default_profile->scripts()->insert(nx_font_css);
|
|
||||||
default_profile->scripts()->insert(load_nx_font);
|
|
||||||
default_profile->scripts()->insert(gamepad);
|
default_profile->scripts()->insert(gamepad);
|
||||||
default_profile->scripts()->insert(window_nx);
|
default_profile->scripts()->insert(window_nx);
|
||||||
|
|
||||||
default_profile->setRequestInterceptor(url_interceptor.get());
|
default_profile->setRequestInterceptor(url_interceptor.get());
|
||||||
|
|
||||||
auto* global_settings = QWebEngineSettings::globalSettings();
|
|
||||||
|
|
||||||
global_settings->setAttribute(QWebEngineSettings::LocalContentCanAccessRemoteUrls, true);
|
global_settings->setAttribute(QWebEngineSettings::LocalContentCanAccessRemoteUrls, true);
|
||||||
global_settings->setAttribute(QWebEngineSettings::FullScreenSupportEnabled, true);
|
global_settings->setAttribute(QWebEngineSettings::FullScreenSupportEnabled, true);
|
||||||
global_settings->setAttribute(QWebEngineSettings::AllowRunningInsecureContent, true);
|
global_settings->setAttribute(QWebEngineSettings::AllowRunningInsecureContent, true);
|
||||||
|
@ -111,13 +84,7 @@ QtNXWebEngineView::QtNXWebEngineView(QWidget* parent, Core::System& system,
|
||||||
global_settings->setAttribute(QWebEngineSettings::AllowWindowActivationFromJavaScript, true);
|
global_settings->setAttribute(QWebEngineSettings::AllowWindowActivationFromJavaScript, true);
|
||||||
global_settings->setAttribute(QWebEngineSettings::ShowScrollBars, false);
|
global_settings->setAttribute(QWebEngineSettings::ShowScrollBars, false);
|
||||||
|
|
||||||
connect(
|
global_settings->setFontFamily(QWebEngineSettings::StandardFont, QStringLiteral("Roboto"));
|
||||||
url_interceptor.get(), &UrlRequestInterceptor::FrameChanged, url_interceptor.get(),
|
|
||||||
[this] {
|
|
||||||
std::this_thread::sleep_for(std::chrono::milliseconds(50));
|
|
||||||
page()->runJavaScript(QString::fromStdString(LOAD_NX_FONT));
|
|
||||||
},
|
|
||||||
Qt::QueuedConnection);
|
|
||||||
|
|
||||||
connect(
|
connect(
|
||||||
page(), &QWebEnginePage::windowCloseRequested, page(),
|
page(), &QWebEnginePage::windowCloseRequested, page(),
|
||||||
|
@ -137,6 +104,9 @@ QtNXWebEngineView::~QtNXWebEngineView() {
|
||||||
|
|
||||||
void QtNXWebEngineView::LoadLocalWebPage(std::string_view main_url,
|
void QtNXWebEngineView::LoadLocalWebPage(std::string_view main_url,
|
||||||
std::string_view additional_args) {
|
std::string_view additional_args) {
|
||||||
|
is_local = true;
|
||||||
|
|
||||||
|
LoadExtractedFonts();
|
||||||
SetUserAgent(UserAgent::WebApplet);
|
SetUserAgent(UserAgent::WebApplet);
|
||||||
SetFinished(false);
|
SetFinished(false);
|
||||||
SetExitReason(Service::AM::Applets::WebExitReason::EndButtonPressed);
|
SetExitReason(Service::AM::Applets::WebExitReason::EndButtonPressed);
|
||||||
|
@ -147,6 +117,20 @@ void QtNXWebEngineView::LoadLocalWebPage(std::string_view main_url,
|
||||||
QString::fromStdString(std::string(additional_args))));
|
QString::fromStdString(std::string(additional_args))));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void QtNXWebEngineView::LoadExternalWebPage(std::string_view main_url,
|
||||||
|
std::string_view additional_args) {
|
||||||
|
is_local = false;
|
||||||
|
|
||||||
|
SetUserAgent(UserAgent::WebApplet);
|
||||||
|
SetFinished(false);
|
||||||
|
SetExitReason(Service::AM::Applets::WebExitReason::EndButtonPressed);
|
||||||
|
SetLastURL("http://localhost/");
|
||||||
|
StartInputThread();
|
||||||
|
|
||||||
|
load(QUrl(QString::fromStdString(std::string(main_url)) +
|
||||||
|
QString::fromStdString(std::string(additional_args))));
|
||||||
|
}
|
||||||
|
|
||||||
void QtNXWebEngineView::SetUserAgent(UserAgent user_agent) {
|
void QtNXWebEngineView::SetUserAgent(UserAgent user_agent) {
|
||||||
const QString user_agent_str = [user_agent] {
|
const QString user_agent_str = [user_agent] {
|
||||||
switch (user_agent) {
|
switch (user_agent) {
|
||||||
|
@ -208,12 +192,16 @@ void QtNXWebEngineView::hide() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void QtNXWebEngineView::keyPressEvent(QKeyEvent* event) {
|
void QtNXWebEngineView::keyPressEvent(QKeyEvent* event) {
|
||||||
|
if (is_local) {
|
||||||
input_subsystem->GetKeyboard()->PressKey(event->key());
|
input_subsystem->GetKeyboard()->PressKey(event->key());
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void QtNXWebEngineView::keyReleaseEvent(QKeyEvent* event) {
|
void QtNXWebEngineView::keyReleaseEvent(QKeyEvent* event) {
|
||||||
|
if (is_local) {
|
||||||
input_subsystem->GetKeyboard()->ReleaseKey(event->key());
|
input_subsystem->GetKeyboard()->ReleaseKey(event->key());
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
template <HIDButton... T>
|
template <HIDButton... T>
|
||||||
void QtNXWebEngineView::HandleWindowFooterButtonPressedOnce() {
|
void QtNXWebEngineView::HandleWindowFooterButtonPressedOnce() {
|
||||||
|
@ -294,7 +282,10 @@ void QtNXWebEngineView::StartInputThread() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void QtNXWebEngineView::StopInputThread() {
|
void QtNXWebEngineView::StopInputThread() {
|
||||||
|
if (is_local) {
|
||||||
QWidget::releaseKeyboard();
|
QWidget::releaseKeyboard();
|
||||||
|
}
|
||||||
|
|
||||||
input_thread_running = false;
|
input_thread_running = false;
|
||||||
if (input_thread.joinable()) {
|
if (input_thread.joinable()) {
|
||||||
input_thread.join();
|
input_thread.join();
|
||||||
|
@ -305,7 +296,9 @@ void QtNXWebEngineView::InputThread() {
|
||||||
// Wait for 1 second before allowing any inputs to be processed.
|
// Wait for 1 second before allowing any inputs to be processed.
|
||||||
std::this_thread::sleep_for(std::chrono::seconds(1));
|
std::this_thread::sleep_for(std::chrono::seconds(1));
|
||||||
|
|
||||||
|
if (is_local) {
|
||||||
QWidget::grabKeyboard();
|
QWidget::grabKeyboard();
|
||||||
|
}
|
||||||
|
|
||||||
while (input_thread_running) {
|
while (input_thread_running) {
|
||||||
input_interpreter->PollInput();
|
input_interpreter->PollInput();
|
||||||
|
@ -326,11 +319,53 @@ void QtNXWebEngineView::InputThread() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void QtNXWebEngineView::LoadExtractedFonts() {
|
||||||
|
QWebEngineScript nx_font_css;
|
||||||
|
QWebEngineScript load_nx_font;
|
||||||
|
|
||||||
|
const QString fonts_dir = QString::fromStdString(Common::FS::SanitizePath(
|
||||||
|
fmt::format("{}/fonts", Common::FS::GetUserPath(Common::FS::UserPath::CacheDir))));
|
||||||
|
|
||||||
|
nx_font_css.setName(QStringLiteral("nx_font_css.js"));
|
||||||
|
load_nx_font.setName(QStringLiteral("load_nx_font.js"));
|
||||||
|
|
||||||
|
nx_font_css.setSourceCode(
|
||||||
|
QString::fromStdString(NX_FONT_CSS)
|
||||||
|
.arg(fonts_dir + QStringLiteral("/FontStandard.ttf"))
|
||||||
|
.arg(fonts_dir + QStringLiteral("/FontChineseSimplified.ttf"))
|
||||||
|
.arg(fonts_dir + QStringLiteral("/FontExtendedChineseSimplified.ttf"))
|
||||||
|
.arg(fonts_dir + QStringLiteral("/FontChineseTraditional.ttf"))
|
||||||
|
.arg(fonts_dir + QStringLiteral("/FontKorean.ttf"))
|
||||||
|
.arg(fonts_dir + QStringLiteral("/FontNintendoExtended.ttf"))
|
||||||
|
.arg(fonts_dir + QStringLiteral("/FontNintendoExtended2.ttf")));
|
||||||
|
load_nx_font.setSourceCode(QString::fromStdString(LOAD_NX_FONT));
|
||||||
|
|
||||||
|
nx_font_css.setInjectionPoint(QWebEngineScript::DocumentReady);
|
||||||
|
load_nx_font.setInjectionPoint(QWebEngineScript::Deferred);
|
||||||
|
|
||||||
|
nx_font_css.setWorldId(QWebEngineScript::MainWorld);
|
||||||
|
load_nx_font.setWorldId(QWebEngineScript::MainWorld);
|
||||||
|
|
||||||
|
nx_font_css.setRunsOnSubFrames(true);
|
||||||
|
load_nx_font.setRunsOnSubFrames(true);
|
||||||
|
|
||||||
|
default_profile->scripts()->insert(nx_font_css);
|
||||||
|
default_profile->scripts()->insert(load_nx_font);
|
||||||
|
|
||||||
|
connect(
|
||||||
|
url_interceptor.get(), &UrlRequestInterceptor::FrameChanged, url_interceptor.get(),
|
||||||
|
[this] {
|
||||||
|
std::this_thread::sleep_for(std::chrono::milliseconds(50));
|
||||||
|
page()->runJavaScript(QString::fromStdString(LOAD_NX_FONT));
|
||||||
|
},
|
||||||
|
Qt::QueuedConnection);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
QtWebBrowser::QtWebBrowser(GMainWindow& main_window) {
|
QtWebBrowser::QtWebBrowser(GMainWindow& main_window) {
|
||||||
connect(this, &QtWebBrowser::MainWindowOpenLocalWebPage, &main_window,
|
connect(this, &QtWebBrowser::MainWindowOpenWebPage, &main_window,
|
||||||
&GMainWindow::WebBrowserOpenLocalWebPage, Qt::QueuedConnection);
|
&GMainWindow::WebBrowserOpenWebPage, Qt::QueuedConnection);
|
||||||
connect(&main_window, &GMainWindow::WebBrowserExtractOfflineRomFS, this,
|
connect(&main_window, &GMainWindow::WebBrowserExtractOfflineRomFS, this,
|
||||||
&QtWebBrowser::MainWindowExtractOfflineRomFS, Qt::QueuedConnection);
|
&QtWebBrowser::MainWindowExtractOfflineRomFS, Qt::QueuedConnection);
|
||||||
connect(&main_window, &GMainWindow::WebBrowserClosed, this,
|
connect(&main_window, &GMainWindow::WebBrowserClosed, this,
|
||||||
|
@ -340,17 +375,32 @@ QtWebBrowser::QtWebBrowser(GMainWindow& main_window) {
|
||||||
QtWebBrowser::~QtWebBrowser() = default;
|
QtWebBrowser::~QtWebBrowser() = default;
|
||||||
|
|
||||||
void QtWebBrowser::OpenLocalWebPage(
|
void QtWebBrowser::OpenLocalWebPage(
|
||||||
std::string_view local_url, std::function<void()> extract_romfs_callback,
|
std::string_view local_url, std::function<void()> extract_romfs_callback_,
|
||||||
std::function<void(Service::AM::Applets::WebExitReason, std::string)> callback) const {
|
std::function<void(Service::AM::Applets::WebExitReason, std::string)> callback_) const {
|
||||||
this->extract_romfs_callback = std::move(extract_romfs_callback);
|
extract_romfs_callback = std::move(extract_romfs_callback_);
|
||||||
this->callback = std::move(callback);
|
callback = std::move(callback_);
|
||||||
|
|
||||||
const auto index = local_url.find('?');
|
const auto index = local_url.find('?');
|
||||||
|
|
||||||
if (index == std::string::npos) {
|
if (index == std::string::npos) {
|
||||||
emit MainWindowOpenLocalWebPage(local_url, "");
|
emit MainWindowOpenWebPage(local_url, "", true);
|
||||||
} else {
|
} else {
|
||||||
emit MainWindowOpenLocalWebPage(local_url.substr(0, index), local_url.substr(index));
|
emit MainWindowOpenWebPage(local_url.substr(0, index), local_url.substr(index), true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void QtWebBrowser::OpenExternalWebPage(
|
||||||
|
std::string_view external_url,
|
||||||
|
std::function<void(Service::AM::Applets::WebExitReason, std::string)> callback_) const {
|
||||||
|
callback = std::move(callback_);
|
||||||
|
|
||||||
|
const auto index = external_url.find('?');
|
||||||
|
|
||||||
|
if (index == std::string::npos) {
|
||||||
|
emit MainWindowOpenWebPage(external_url, "", false);
|
||||||
|
} else {
|
||||||
|
emit MainWindowOpenWebPage(external_url.substr(0, index), external_url.substr(index),
|
||||||
|
false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -18,8 +18,8 @@
|
||||||
|
|
||||||
enum class HIDButton : u8;
|
enum class HIDButton : u8;
|
||||||
|
|
||||||
class InputInterpreter;
|
|
||||||
class GMainWindow;
|
class GMainWindow;
|
||||||
|
class InputInterpreter;
|
||||||
class UrlRequestInterceptor;
|
class UrlRequestInterceptor;
|
||||||
|
|
||||||
namespace Core {
|
namespace Core {
|
||||||
|
@ -41,6 +41,9 @@ enum class UserAgent {
|
||||||
WifiWebAuthApplet,
|
WifiWebAuthApplet,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class QWebEngineProfile;
|
||||||
|
class QWebEngineSettings;
|
||||||
|
|
||||||
class QtNXWebEngineView : public QWebEngineView {
|
class QtNXWebEngineView : public QWebEngineView {
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
|
@ -57,6 +60,14 @@ public:
|
||||||
*/
|
*/
|
||||||
void LoadLocalWebPage(std::string_view main_url, std::string_view additional_args);
|
void LoadLocalWebPage(std::string_view main_url, std::string_view additional_args);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Loads an external website. Cannot be used to load local urls.
|
||||||
|
*
|
||||||
|
* @param main_url The url to the website.
|
||||||
|
* @param additional_args Additional arguments appended to the main url.
|
||||||
|
*/
|
||||||
|
void LoadExternalWebPage(std::string_view main_url, std::string_view additional_args);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the background color of the web page.
|
* Sets the background color of the web page.
|
||||||
*
|
*
|
||||||
|
@ -147,6 +158,9 @@ private:
|
||||||
/// The thread where input is being polled and processed.
|
/// The thread where input is being polled and processed.
|
||||||
void InputThread();
|
void InputThread();
|
||||||
|
|
||||||
|
/// Loads the extracted fonts using JavaScript.
|
||||||
|
void LoadExtractedFonts();
|
||||||
|
|
||||||
InputCommon::InputSubsystem* input_subsystem;
|
InputCommon::InputSubsystem* input_subsystem;
|
||||||
|
|
||||||
std::unique_ptr<UrlRequestInterceptor> url_interceptor;
|
std::unique_ptr<UrlRequestInterceptor> url_interceptor;
|
||||||
|
@ -163,6 +177,11 @@ private:
|
||||||
Service::AM::Applets::WebExitReason::EndButtonPressed};
|
Service::AM::Applets::WebExitReason::EndButtonPressed};
|
||||||
|
|
||||||
std::string last_url{"http://localhost/"};
|
std::string last_url{"http://localhost/"};
|
||||||
|
|
||||||
|
bool is_local{};
|
||||||
|
|
||||||
|
QWebEngineProfile* default_profile;
|
||||||
|
QWebEngineSettings* global_settings;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -174,13 +193,17 @@ public:
|
||||||
explicit QtWebBrowser(GMainWindow& parent);
|
explicit QtWebBrowser(GMainWindow& parent);
|
||||||
~QtWebBrowser() override;
|
~QtWebBrowser() override;
|
||||||
|
|
||||||
void OpenLocalWebPage(std::string_view local_url, std::function<void()> extract_romfs_callback,
|
void OpenLocalWebPage(std::string_view local_url, std::function<void()> extract_romfs_callback_,
|
||||||
std::function<void(Service::AM::Applets::WebExitReason, std::string)>
|
std::function<void(Service::AM::Applets::WebExitReason, std::string)>
|
||||||
callback) const override;
|
callback_) const override;
|
||||||
|
|
||||||
|
void OpenExternalWebPage(std::string_view external_url,
|
||||||
|
std::function<void(Service::AM::Applets::WebExitReason, std::string)>
|
||||||
|
callback_) const override;
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void MainWindowOpenLocalWebPage(std::string_view main_url,
|
void MainWindowOpenWebPage(std::string_view main_url, std::string_view additional_args,
|
||||||
std::string_view additional_args) const;
|
bool is_local) const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void MainWindowExtractOfflineRomFS();
|
void MainWindowExtractOfflineRomFS();
|
||||||
|
|
|
@ -366,13 +366,13 @@ void GMainWindow::SoftwareKeyboardInvokeCheckDialog(std::u16string error_message
|
||||||
emit SoftwareKeyboardFinishedCheckDialog();
|
emit SoftwareKeyboardFinishedCheckDialog();
|
||||||
}
|
}
|
||||||
|
|
||||||
void GMainWindow::WebBrowserOpenLocalWebPage(std::string_view main_url,
|
void GMainWindow::WebBrowserOpenWebPage(std::string_view main_url, std::string_view additional_args,
|
||||||
std::string_view additional_args) {
|
bool is_local) {
|
||||||
#ifdef YUZU_USE_QT_WEB_ENGINE
|
#ifdef YUZU_USE_QT_WEB_ENGINE
|
||||||
|
|
||||||
if (disable_web_applet) {
|
if (disable_web_applet) {
|
||||||
emit WebBrowserClosed(Service::AM::Applets::WebExitReason::WindowClosed,
|
emit WebBrowserClosed(Service::AM::Applets::WebExitReason::WindowClosed,
|
||||||
"http://localhost");
|
"http://localhost/");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -388,7 +388,7 @@ void GMainWindow::WebBrowserOpenLocalWebPage(std::string_view main_url,
|
||||||
loading_progress.setRange(0, 3);
|
loading_progress.setRange(0, 3);
|
||||||
loading_progress.setValue(0);
|
loading_progress.setValue(0);
|
||||||
|
|
||||||
if (!Common::FS::Exists(std::string(main_url))) {
|
if (is_local && !Common::FS::Exists(std::string(main_url))) {
|
||||||
loading_progress.show();
|
loading_progress.show();
|
||||||
|
|
||||||
auto future = QtConcurrent::run([this] { emit WebBrowserExtractOfflineRomFS(); });
|
auto future = QtConcurrent::run([this] { emit WebBrowserExtractOfflineRomFS(); });
|
||||||
|
@ -400,7 +400,11 @@ void GMainWindow::WebBrowserOpenLocalWebPage(std::string_view main_url,
|
||||||
|
|
||||||
loading_progress.setValue(1);
|
loading_progress.setValue(1);
|
||||||
|
|
||||||
|
if (is_local) {
|
||||||
web_browser_view.LoadLocalWebPage(main_url, additional_args);
|
web_browser_view.LoadLocalWebPage(main_url, additional_args);
|
||||||
|
} else {
|
||||||
|
web_browser_view.LoadExternalWebPage(main_url, additional_args);
|
||||||
|
}
|
||||||
|
|
||||||
if (render_window->IsLoadingComplete()) {
|
if (render_window->IsLoadingComplete()) {
|
||||||
render_window->hide();
|
render_window->hide();
|
||||||
|
@ -493,7 +497,7 @@ void GMainWindow::WebBrowserOpenLocalWebPage(std::string_view main_url,
|
||||||
#else
|
#else
|
||||||
|
|
||||||
// Utilize the same fallback as the default web browser applet.
|
// Utilize the same fallback as the default web browser applet.
|
||||||
emit WebBrowserClosed(Service::AM::Applets::WebExitReason::WindowClosed, "http://localhost");
|
emit WebBrowserClosed(Service::AM::Applets::WebExitReason::WindowClosed, "http://localhost/");
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
|
@ -142,7 +142,8 @@ public slots:
|
||||||
void ProfileSelectorSelectProfile();
|
void ProfileSelectorSelectProfile();
|
||||||
void SoftwareKeyboardGetText(const Core::Frontend::SoftwareKeyboardParameters& parameters);
|
void SoftwareKeyboardGetText(const Core::Frontend::SoftwareKeyboardParameters& parameters);
|
||||||
void SoftwareKeyboardInvokeCheckDialog(std::u16string error_message);
|
void SoftwareKeyboardInvokeCheckDialog(std::u16string error_message);
|
||||||
void WebBrowserOpenLocalWebPage(std::string_view main_url, std::string_view additional_args);
|
void WebBrowserOpenWebPage(std::string_view main_url, std::string_view additional_args,
|
||||||
|
bool is_local);
|
||||||
void OnAppFocusStateChanged(Qt::ApplicationState state);
|
void OnAppFocusStateChanged(Qt::ApplicationState state);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
Loading…
Reference in a new issue