Skip to content
Snippets Groups Projects
Commit cec166db authored by Ming Rui Zhang's avatar Ming Rui Zhang
Browse files

pluginmodel: add modelUpdated signals for updating client properties

Change-Id: I6782735d31a3686cd06d2235b0f55b027468f347
parent 5622fba7
No related branches found
No related tags found
No related merge requests found
...@@ -181,6 +181,7 @@ public: ...@@ -181,6 +181,7 @@ public:
Q_SIGNALS: Q_SIGNALS:
void chatHandlerStatusUpdated(bool isVisible); void chatHandlerStatusUpdated(bool isVisible);
void modelUpdated();
}; };
} // namespace api } // namespace api
......
...@@ -53,9 +53,11 @@ PluginModel::setPluginsEnabled(bool enable) ...@@ -53,9 +53,11 @@ PluginModel::setPluginsEnabled(bool enable)
{ {
PluginManager::instance().setPluginsEnabled(enable); PluginManager::instance().setPluginsEnabled(enable);
if (!enable) if (!enable)
emit chatHandlerStatusUpdated(false); Q_EMIT chatHandlerStatusUpdated(false);
else else
emit chatHandlerStatusUpdated(getChatHandlers().size() > 0); Q_EMIT chatHandlerStatusUpdated(getChatHandlers().size() > 0);
Q_EMIT modelUpdated();
} }
bool bool
...@@ -102,7 +104,9 @@ bool ...@@ -102,7 +104,9 @@ bool
PluginModel::installPlugin(const QString& jplPath, bool force) PluginModel::installPlugin(const QString& jplPath, bool force)
{ {
if (getPluginsEnabled()) { if (getPluginsEnabled()) {
return PluginManager::instance().installPlugin(jplPath, force); auto result = PluginManager::instance().installPlugin(jplPath, force);
Q_EMIT modelUpdated();
return result;
} }
return false; return false;
} }
...@@ -110,13 +114,16 @@ PluginModel::installPlugin(const QString& jplPath, bool force) ...@@ -110,13 +114,16 @@ PluginModel::installPlugin(const QString& jplPath, bool force)
bool bool
PluginModel::uninstallPlugin(const QString& rootPath) PluginModel::uninstallPlugin(const QString& rootPath)
{ {
return PluginManager::instance().uninstallPlugin(rootPath); auto result = PluginManager::instance().uninstallPlugin(rootPath);
Q_EMIT modelUpdated();
return result;
} }
bool bool
PluginModel::loadPlugin(const QString& path) PluginModel::loadPlugin(const QString& path)
{ {
bool status = PluginManager::instance().loadPlugin(path); bool status = PluginManager::instance().loadPlugin(path);
Q_EMIT modelUpdated();
if (getChatHandlers().size() > 0) if (getChatHandlers().size() > 0)
emit chatHandlerStatusUpdated(getPluginsEnabled()); emit chatHandlerStatusUpdated(getPluginsEnabled());
return status; return status;
...@@ -126,6 +133,7 @@ bool ...@@ -126,6 +133,7 @@ bool
PluginModel::unloadPlugin(const QString& path) PluginModel::unloadPlugin(const QString& path)
{ {
bool status = PluginManager::instance().unloadPlugin(path); bool status = PluginManager::instance().unloadPlugin(path);
Q_EMIT modelUpdated();
if (getChatHandlers().size() <= 0) if (getChatHandlers().size() <= 0)
emit chatHandlerStatusUpdated(false); emit chatHandlerStatusUpdated(false);
return status; return status;
...@@ -143,6 +151,7 @@ PluginModel::toggleCallMediaHandler(const QString& mediaHandlerId, ...@@ -143,6 +151,7 @@ PluginModel::toggleCallMediaHandler(const QString& mediaHandlerId,
bool toggle) bool toggle)
{ {
PluginManager::instance().toggleCallMediaHandler(mediaHandlerId, callId, toggle); PluginManager::instance().toggleCallMediaHandler(mediaHandlerId, callId, toggle);
Q_EMIT modelUpdated();
} }
VectorString VectorString
...@@ -158,6 +167,7 @@ PluginModel::toggleChatHandler(const QString& chatHandlerId, ...@@ -158,6 +167,7 @@ PluginModel::toggleChatHandler(const QString& chatHandlerId,
bool toggle) bool toggle)
{ {
PluginManager::instance().toggleChatHandler(chatHandlerId, accountId, peerId, toggle); PluginManager::instance().toggleChatHandler(chatHandlerId, accountId, peerId, toggle);
Q_EMIT modelUpdated();
} }
VectorString VectorString
...@@ -219,7 +229,9 @@ PluginModel::getPluginPreferences(const QString& path) ...@@ -219,7 +229,9 @@ PluginModel::getPluginPreferences(const QString& path)
bool bool
PluginModel::setPluginPreference(const QString& path, const QString& key, const QString& value) PluginModel::setPluginPreference(const QString& path, const QString& key, const QString& value)
{ {
return PluginManager::instance().setPluginPreference(path, key, value); auto result = PluginManager::instance().setPluginPreference(path, key, value);
Q_EMIT modelUpdated();
return result;
} }
MapStringString MapStringString
...@@ -231,7 +243,9 @@ PluginModel::getPluginPreferencesValues(const QString& path) ...@@ -231,7 +243,9 @@ PluginModel::getPluginPreferencesValues(const QString& path)
bool bool
PluginModel::resetPluginPreferencesValues(const QString& path) PluginModel::resetPluginPreferencesValues(const QString& path)
{ {
return PluginManager::instance().resetPluginPreferencesValues(path); auto result = PluginManager::instance().resetPluginPreferencesValues(path);
Q_EMIT modelUpdated();
return result;
} }
} // namespace lrc } // namespace lrc
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment