Settings Rework

* Add JSON string configuration field to RGBController to store device-specific configurations
    * This JSON string holds both configuration and schema
    * Add settings schema tracking to SettingsManager
    * Implement dynamic settings widget that generates a settings UI based on a JSON schema
    * Implement SettingsManager callback for notifying of settings changes and settings schema updates
    * Always enable Entire Device zone option and use it to enable Edit Device
    * Rename SaveSizes to SaveConfiguration in ProfileManager and Sizes.json to Configuration.json
    * Add zone flag for indicating that a zone's geometry may change, informing profile manager to ignore this check
    * Remove Theme setting and Theme Manager, as this didn't work on most setups anyways and Qt6 has proper Windows dark theming
This commit is contained in:
Adam Honse
2026-04-15 11:51:28 -05:00
parent 5ab2c8de69
commit 17313f0d94
75 changed files with 3415 additions and 3028 deletions

View File

@@ -32,6 +32,13 @@ void PluginManagerResourceManagerCallback(void * this_ptr, unsigned int update_r
this_obj->ResourceManagerCallback(update_reason);
}
void PluginManagerSettingsManagerCallback(void * this_ptr, unsigned int update_reason)
{
PluginManager * this_obj = (PluginManager *)this_ptr;
this_obj->SettingsManagerCallback(update_reason);
}
PluginManager::PluginManager()
{
/*-----------------------------------------------------*\
@@ -54,6 +61,7 @@ PluginManager::PluginManager()
\*-----------------------------------------------------*/
ResourceManager::get()->GetProfileManager()->RegisterProfileManagerCallback(PluginManagerProfileManagerCallback, this);
ResourceManager::get()->RegisterResourceManagerCallback(PluginManagerResourceManagerCallback, this);
ResourceManager::get()->GetSettingsManager()->RegisterSettingsManagerCallback(PluginManagerSettingsManagerCallback, this);
}
PluginManager::~PluginManager()
@@ -61,8 +69,9 @@ PluginManager::~PluginManager()
/*-----------------------------------------------------*\
| Unegister callbacks |
\*-----------------------------------------------------*/
ResourceManager::get()->GetProfileManager()->RegisterProfileManagerCallback(PluginManagerProfileManagerCallback, this);
ResourceManager::get()->RegisterResourceManagerCallback(PluginManagerResourceManagerCallback, this);
ResourceManager::get()->GetProfileManager()->UnregisterProfileManagerCallback(PluginManagerProfileManagerCallback, this);
ResourceManager::get()->UnregisterResourceManagerCallback(PluginManagerResourceManagerCallback, this);
ResourceManager::get()->GetSettingsManager()->UnregisterSettingsManagerCallback(PluginManagerSettingsManagerCallback, this);
}
void PluginManager::RegisterAddPluginCallback(AddPluginCallback new_callback, void * new_callback_arg)
@@ -682,6 +691,17 @@ void PluginManager::ResourceManagerCallback(unsigned int update_reason)
}
}
void PluginManager::SettingsManagerCallback(unsigned int update_reason)
{
for(std::size_t plugin_idx = 0; plugin_idx < ActivePlugins.size(); plugin_idx++)
{
if(ActivePlugins[plugin_idx].enabled && ActivePlugins[plugin_idx].loader->isLoaded())
{
ActivePlugins[plugin_idx].plugin->SettingsManagerUpdated(update_reason);
}
}
}
/*---------------------------------------------------------*\
| Plugin Information |
\*---------------------------------------------------------*/