mirror of
https://github.com/ciphervance/supercell-wx.git
synced 2025-10-30 21:40:05 +00:00
Add storm tracking information to settings
This commit is contained in:
parent
5b9df2b61a
commit
5e0f69018b
5 changed files with 128 additions and 1 deletions
|
|
@ -158,6 +158,7 @@ set(HDR_SETTINGS source/scwx/qt/settings/audio_settings.hpp
|
|||
source/scwx/qt/settings/general_settings.hpp
|
||||
source/scwx/qt/settings/map_settings.hpp
|
||||
source/scwx/qt/settings/palette_settings.hpp
|
||||
source/scwx/qt/settings/product_settings.hpp
|
||||
source/scwx/qt/settings/settings_category.hpp
|
||||
source/scwx/qt/settings/settings_container.hpp
|
||||
source/scwx/qt/settings/settings_definitions.hpp
|
||||
|
|
@ -171,6 +172,7 @@ set(SRC_SETTINGS source/scwx/qt/settings/audio_settings.cpp
|
|||
source/scwx/qt/settings/general_settings.cpp
|
||||
source/scwx/qt/settings/map_settings.cpp
|
||||
source/scwx/qt/settings/palette_settings.cpp
|
||||
source/scwx/qt/settings/product_settings.cpp
|
||||
source/scwx/qt/settings/settings_category.cpp
|
||||
source/scwx/qt/settings/settings_container.cpp
|
||||
source/scwx/qt/settings/settings_interface.cpp
|
||||
|
|
|
|||
|
|
@ -4,6 +4,7 @@
|
|||
#include <scwx/qt/settings/general_settings.hpp>
|
||||
#include <scwx/qt/settings/map_settings.hpp>
|
||||
#include <scwx/qt/settings/palette_settings.hpp>
|
||||
#include <scwx/qt/settings/product_settings.hpp>
|
||||
#include <scwx/qt/settings/text_settings.hpp>
|
||||
#include <scwx/qt/settings/ui_settings.hpp>
|
||||
#include <scwx/qt/util/json.hpp>
|
||||
|
|
@ -116,6 +117,7 @@ void SettingsManager::Shutdown()
|
|||
|
||||
dataChanged |= settings::GeneralSettings::Instance().Shutdown();
|
||||
dataChanged |= settings::MapSettings::Instance().Shutdown();
|
||||
dataChanged |= settings::ProductSettings::Instance().Shutdown();
|
||||
dataChanged |= settings::UiSettings::Instance().Shutdown();
|
||||
|
||||
if (dataChanged)
|
||||
|
|
@ -132,6 +134,7 @@ boost::json::value SettingsManager::Impl::ConvertSettingsToJson()
|
|||
settings::AudioSettings::Instance().WriteJson(settingsJson);
|
||||
settings::MapSettings::Instance().WriteJson(settingsJson);
|
||||
settings::PaletteSettings::Instance().WriteJson(settingsJson);
|
||||
settings::ProductSettings::Instance().WriteJson(settingsJson);
|
||||
settings::TextSettings::Instance().WriteJson(settingsJson);
|
||||
settings::UiSettings::Instance().WriteJson(settingsJson);
|
||||
|
||||
|
|
@ -146,6 +149,7 @@ void SettingsManager::Impl::GenerateDefaultSettings()
|
|||
settings::AudioSettings::Instance().SetDefaults();
|
||||
settings::MapSettings::Instance().SetDefaults();
|
||||
settings::PaletteSettings::Instance().SetDefaults();
|
||||
settings::ProductSettings::Instance().SetDefaults();
|
||||
settings::TextSettings::Instance().SetDefaults();
|
||||
settings::UiSettings::Instance().SetDefaults();
|
||||
}
|
||||
|
|
@ -161,6 +165,7 @@ bool SettingsManager::Impl::LoadSettings(
|
|||
jsonDirty |= !settings::AudioSettings::Instance().ReadJson(settingsJson);
|
||||
jsonDirty |= !settings::MapSettings::Instance().ReadJson(settingsJson);
|
||||
jsonDirty |= !settings::PaletteSettings::Instance().ReadJson(settingsJson);
|
||||
jsonDirty |= !settings::ProductSettings::Instance().ReadJson(settingsJson);
|
||||
jsonDirty |= !settings::TextSettings::Instance().ReadJson(settingsJson);
|
||||
jsonDirty |= !settings::UiSettings::Instance().ReadJson(settingsJson);
|
||||
|
||||
|
|
|
|||
75
scwx-qt/source/scwx/qt/settings/product_settings.cpp
Normal file
75
scwx-qt/source/scwx/qt/settings/product_settings.cpp
Normal file
|
|
@ -0,0 +1,75 @@
|
|||
#include <scwx/qt/settings/product_settings.hpp>
|
||||
#include <scwx/qt/settings/settings_container.hpp>
|
||||
|
||||
namespace scwx
|
||||
{
|
||||
namespace qt
|
||||
{
|
||||
namespace settings
|
||||
{
|
||||
|
||||
static const std::string logPrefix_ = "scwx::qt::settings::product_settings";
|
||||
|
||||
class ProductSettings::Impl
|
||||
{
|
||||
public:
|
||||
explicit Impl()
|
||||
{
|
||||
stiForecastEnabled_.SetDefault(true);
|
||||
stiPastEnabled_.SetDefault(true);
|
||||
}
|
||||
|
||||
~Impl() {}
|
||||
|
||||
SettingsVariable<bool> stiForecastEnabled_ {"sti_forecast_enabled"};
|
||||
SettingsVariable<bool> stiPastEnabled_ {"sti_past_enabled"};
|
||||
};
|
||||
|
||||
ProductSettings::ProductSettings() :
|
||||
SettingsCategory("product"), p(std::make_unique<Impl>())
|
||||
{
|
||||
RegisterVariables({&p->stiForecastEnabled_, &p->stiPastEnabled_});
|
||||
SetDefaults();
|
||||
}
|
||||
ProductSettings::~ProductSettings() = default;
|
||||
|
||||
ProductSettings::ProductSettings(ProductSettings&&) noexcept = default;
|
||||
ProductSettings&
|
||||
ProductSettings::operator=(ProductSettings&&) noexcept = default;
|
||||
|
||||
SettingsVariable<bool>& ProductSettings::sti_forecast_enabled() const
|
||||
{
|
||||
return p->stiForecastEnabled_;
|
||||
}
|
||||
|
||||
SettingsVariable<bool>& ProductSettings::sti_past_enabled() const
|
||||
{
|
||||
return p->stiPastEnabled_;
|
||||
}
|
||||
|
||||
bool ProductSettings::Shutdown()
|
||||
{
|
||||
bool dataChanged = false;
|
||||
|
||||
// Commit settings that are managed separate from the settings dialog
|
||||
dataChanged |= p->stiForecastEnabled_.Commit();
|
||||
dataChanged |= p->stiPastEnabled_.Commit();
|
||||
|
||||
return dataChanged;
|
||||
}
|
||||
|
||||
ProductSettings& ProductSettings::Instance()
|
||||
{
|
||||
static ProductSettings generalSettings_;
|
||||
return generalSettings_;
|
||||
}
|
||||
|
||||
bool operator==(const ProductSettings& lhs, const ProductSettings& rhs)
|
||||
{
|
||||
return (lhs.p->stiForecastEnabled_ == rhs.p->stiForecastEnabled_ &&
|
||||
lhs.p->stiPastEnabled_ == rhs.p->stiPastEnabled_);
|
||||
}
|
||||
|
||||
} // namespace settings
|
||||
} // namespace qt
|
||||
} // namespace scwx
|
||||
45
scwx-qt/source/scwx/qt/settings/product_settings.hpp
Normal file
45
scwx-qt/source/scwx/qt/settings/product_settings.hpp
Normal file
|
|
@ -0,0 +1,45 @@
|
|||
#pragma once
|
||||
|
||||
#include <scwx/qt/settings/settings_category.hpp>
|
||||
#include <scwx/qt/settings/settings_variable.hpp>
|
||||
|
||||
#include <memory>
|
||||
#include <string>
|
||||
|
||||
namespace scwx
|
||||
{
|
||||
namespace qt
|
||||
{
|
||||
namespace settings
|
||||
{
|
||||
|
||||
class ProductSettings : public SettingsCategory
|
||||
{
|
||||
public:
|
||||
explicit ProductSettings();
|
||||
~ProductSettings();
|
||||
|
||||
ProductSettings(const ProductSettings&) = delete;
|
||||
ProductSettings& operator=(const ProductSettings&) = delete;
|
||||
|
||||
ProductSettings(ProductSettings&&) noexcept;
|
||||
ProductSettings& operator=(ProductSettings&&) noexcept;
|
||||
|
||||
SettingsVariable<bool>& sti_forecast_enabled() const;
|
||||
SettingsVariable<bool>& sti_past_enabled() const;
|
||||
|
||||
static ProductSettings& Instance();
|
||||
|
||||
friend bool operator==(const ProductSettings& lhs,
|
||||
const ProductSettings& rhs);
|
||||
|
||||
bool Shutdown();
|
||||
|
||||
private:
|
||||
class Impl;
|
||||
std::unique_ptr<Impl> p;
|
||||
};
|
||||
|
||||
} // namespace settings
|
||||
} // namespace qt
|
||||
} // namespace scwx
|
||||
|
|
@ -1 +1 @@
|
|||
Subproject commit 90331f7654586302b223d88329846929514bc883
|
||||
Subproject commit 0446ff708b387728faf8d2dbb3862a757067c2ee
|
||||
Loading…
Add table
Add a link
Reference in a new issue