mirror of https://github.com/WerWolv/ImHex.git
feat: Properly detect native theme on the web version
This commit is contained in:
parent
13c9b80bca
commit
eb41622a38
|
@ -5,6 +5,8 @@
|
|||
#include <emscripten.h>
|
||||
#include <emscripten/html5.h>
|
||||
|
||||
#include <hex/api/event.hpp>
|
||||
|
||||
// Function used by c++ to get the size of the html canvas
|
||||
EM_JS(int, canvas_get_width, (), {
|
||||
return Module.canvas.width;
|
||||
|
@ -20,6 +22,21 @@ EM_JS(void, resizeCanvas, (), {
|
|||
js_resizeCanvas();
|
||||
});
|
||||
|
||||
EM_JS(void, setupThemeListener, (), {
|
||||
window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', event => {
|
||||
Module._handleThemeChange();
|
||||
});
|
||||
});
|
||||
|
||||
EM_JS(bool, isDarkModeEnabled, (), {
|
||||
return window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches
|
||||
});
|
||||
|
||||
EMSCRIPTEN_KEEPALIVE
|
||||
extern "C" void handleThemeChange() {
|
||||
hex::EventManager::post<hex::EventOSThemeChanged>();
|
||||
}
|
||||
|
||||
namespace hex {
|
||||
|
||||
void nativeErrorMessage(const std::string &message) {
|
||||
|
@ -45,6 +62,17 @@ namespace hex {
|
|||
|
||||
void Window::setupNativeWindow() {
|
||||
resizeCanvas();
|
||||
setupThemeListener();
|
||||
|
||||
bool themeFollowSystem = ImHexApi::System::usesSystemThemeDetection();
|
||||
EventManager::subscribe<EventOSThemeChanged>(this, [themeFollowSystem] {
|
||||
if (!themeFollowSystem) return;
|
||||
|
||||
EventManager::post<RequestChangeTheme>(!isDarkModeEnabled() ? "Light" : "Dark");
|
||||
});
|
||||
|
||||
if (themeFollowSystem)
|
||||
EventManager::post<EventOSThemeChanged>();
|
||||
}
|
||||
|
||||
void Window::beginNativeWindowFrame() {
|
||||
|
|
Loading…
Reference in New Issue