Merge branch 'fix-theme-api' into 'master'

Fix theme api

See merge request openlp/openlp!265
This commit is contained in:
Raoul Snyman 2020-10-28 04:06:56 +00:00
commit 578c627d24
4 changed files with 12 additions and 4 deletions

View File

@ -223,10 +223,10 @@ def set_theme():
abort(400) abort(400)
if theme_level == ThemeLevel.Global: if theme_level == ThemeLevel.Global:
Registry().get('settings').setValue('themes/global theme', theme) Registry().get('settings').setValue('themes/global theme', theme)
Registry().execute('theme_update_global') Registry().get('theme_manager').theme_update_global.emit()
elif theme_level == ThemeLevel.Service: elif theme_level == ThemeLevel.Service:
Registry().get('settings').setValue('servicemanager/service theme', theme) Registry().get('settings').setValue('servicemanager/service theme', theme)
Registry().execute('theme_update_service') Registry().get('service_manager').theme_update_service.emit()
elif theme_level == ThemeLevel.Song: elif theme_level == ThemeLevel.Song:
log.error('Unimplemented method') log.error('Unimplemented method')
return '', 501 return '', 501

View File

@ -302,7 +302,6 @@ class Ui_ServiceManager(object):
Registry().register_function('theme_update_list', self.update_theme_list) Registry().register_function('theme_update_list', self.update_theme_list)
Registry().register_function('config_screen_changed', self.regenerate_service_items) Registry().register_function('config_screen_changed', self.regenerate_service_items)
Registry().register_function('theme_update_global', self.theme_change) Registry().register_function('theme_update_global', self.theme_change)
Registry().register_function('theme_update_service', self.service_theme_change)
Registry().register_function('mediaitem_suffix_reset', self.reset_supported_suffixes) Registry().register_function('mediaitem_suffix_reset', self.reset_supported_suffixes)
@ -317,6 +316,7 @@ class ServiceManager(QtWidgets.QWidget, RegistryBase, Ui_ServiceManager, LogMixi
servicemanager_next_item = QtCore.pyqtSignal() servicemanager_next_item = QtCore.pyqtSignal()
servicemanager_previous_item = QtCore.pyqtSignal() servicemanager_previous_item = QtCore.pyqtSignal()
servicemanager_new_file = QtCore.pyqtSignal() servicemanager_new_file = QtCore.pyqtSignal()
theme_update_service = QtCore.pyqtSignal()
def __init__(self, parent=None): def __init__(self, parent=None):
""" """
@ -346,6 +346,7 @@ class ServiceManager(QtWidgets.QWidget, RegistryBase, Ui_ServiceManager, LogMixi
self.servicemanager_next_item.connect(self.next_item) self.servicemanager_next_item.connect(self.next_item)
self.servicemanager_previous_item.connect(self.previous_item) self.servicemanager_previous_item.connect(self.previous_item)
self.servicemanager_new_file.connect(self.new_file) self.servicemanager_new_file.connect(self.new_file)
self.theme_update_service.connect(self.service_theme_change)
def bootstrap_post_set_up(self): def bootstrap_post_set_up(self):
""" """
@ -1355,7 +1356,7 @@ class ServiceManager(QtWidgets.QWidget, RegistryBase, Ui_ServiceManager, LogMixi
""" """
self.service_theme = self.theme_combo_box.currentText() self.service_theme = self.theme_combo_box.currentText()
self.settings.setValue('servicemanager/service theme', self.service_theme) self.settings.setValue('servicemanager/service theme', self.service_theme)
Registry().execute('theme_update_service') self.service_theme_change()
def theme_change(self): def theme_change(self):
""" """

View File

@ -136,6 +136,8 @@ class ThemeManager(QtWidgets.QWidget, RegistryBase, Ui_ThemeManager, LogMixin, R
""" """
Manages the orders of Theme. Manages the orders of Theme.
""" """
theme_update_global = QtCore.pyqtSignal()
def __init__(self, parent=None): def __init__(self, parent=None):
""" """
Constructor Constructor
@ -167,6 +169,7 @@ class ThemeManager(QtWidgets.QWidget, RegistryBase, Ui_ThemeManager, LogMixin, R
self.setup_ui(self) self.setup_ui(self)
self.global_theme = self.settings.value('themes/global theme') self.global_theme = self.settings.value('themes/global theme')
self.build_theme_path() self.build_theme_path()
self.theme_update_global.connect(self.change_global_from_tab)
def bootstrap_post_set_up(self): def bootstrap_post_set_up(self):
""" """

View File

@ -229,12 +229,16 @@ def test_controller_set_theme_aborts_if_no_theme(flask_client, settings):
def test_controller_set_theme_sets_global_theme(flask_client, settings): def test_controller_set_theme_sets_global_theme(flask_client, settings):
fake_theme_manager = MagicMock()
Registry().register('theme_manager', fake_theme_manager)
settings.setValue('themes/theme level', 1) settings.setValue('themes/theme level', 1)
res = flask_client.post('/api/v2/controller/theme', json=dict(theme='test')) res = flask_client.post('/api/v2/controller/theme', json=dict(theme='test'))
assert res.status_code == 204 assert res.status_code == 204
def test_controller_set_theme_sets_service_theme(flask_client, settings): def test_controller_set_theme_sets_service_theme(flask_client, settings):
fake_service_manager = MagicMock()
Registry().register('service_manager', fake_service_manager)
settings.setValue('themes/theme level', 2) settings.setValue('themes/theme level', 2)
res = flask_client.post('/api/v2/controller/theme', json=dict(theme='test')) res = flask_client.post('/api/v2/controller/theme', json=dict(theme='test'))
assert res.status_code == 204 assert res.status_code == 204