Merge branch 'fix-show-presentation-after-media' into 'master'

Fix of problem showing presentations after media items

Closes #833

See merge request openlp/openlp!362
This commit is contained in:
Tim Bentley 2021-09-12 08:28:37 +00:00
commit df0163b144
4 changed files with 7 additions and 11 deletions

View File

@ -664,12 +664,6 @@ class MediaController(RegistryBase, LogMixin, RegistryProperties):
self.log_debug('media_reset') self.log_debug('media_reset')
self.set_controls_visible(controller, False) self.set_controls_visible(controller, False)
if controller.controller_type in self.current_media_players: if controller.controller_type in self.current_media_players:
display = self._define_display(controller)
hide_mode = controller.get_hide_mode()
if hide_mode is None:
display.show_display()
else:
display.hide_display(hide_mode)
self.current_media_players[controller.controller_type].reset(controller) self.current_media_players[controller.controller_type].reset(controller)
if controller.is_live and delayed: if controller.is_live and delayed:
self.live_kill_timer.start(HIDE_DELAY_TIME) self.live_kill_timer.start(HIDE_DELAY_TIME)

View File

@ -952,11 +952,16 @@ class SlideController(QtWidgets.QWidget, LogMixin, RegistryProperties):
self.info_label.setText(self.service_item.title) self.info_label.setText(self.service_item.title)
self.slide_list = {} self.slide_list = {}
if old_item: if old_item:
# Close the old item if it's not to be used by the new sevice item # Close the old item if it's not to be used by the new service item
if not self.service_item.is_media() and not self.service_item.requires_media(): if not self.service_item.is_media() and not self.service_item.requires_media():
self.on_media_close() self.on_media_close()
if old_item.is_command() and not old_item.is_media(): if old_item.is_command() and not old_item.is_media():
Registry().execute('{name}_stop'.format(name=old_item.name.lower()), [old_item, self.is_live]) Registry().execute('{name}_stop'.format(name=old_item.name.lower()), [old_item, self.is_live])
# if the old item was media which hid the main display then need to reset it if new service item uses it
if self.is_live and self._current_hide_mode is None and old_item.is_media() and not \
old_item.requires_media() and not self.service_item.is_capable(ItemCapabilities.ProvidesOwnDisplay):
for display in self.displays:
display.show_display()
row = 0 row = 0
width = self.main_window.control_splitter.sizes()[self.split] width = self.main_window.control_splitter.sizes()[self.split]
if self.service_item.is_text(): if self.service_item.is_text():

View File

@ -282,21 +282,17 @@ def test_media_reset(media_env):
# GIVEN: A media controller, mocked slide controller, mocked media player and mocked display # GIVEN: A media controller, mocked slide controller, mocked media player and mocked display
mocked_slide_controller = MagicMock() mocked_slide_controller = MagicMock()
mocked_media_player = MagicMock() mocked_media_player = MagicMock()
mocked_display = MagicMock(hide_mode=None)
mocked_slide_controller.controller_type = 'media player' mocked_slide_controller.controller_type = 'media player'
mocked_slide_controller.media_info = MagicMock(is_background=False) mocked_slide_controller.media_info = MagicMock(is_background=False)
mocked_slide_controller.get_hide_mode = MagicMock(return_value=None)
mocked_slide_controller.is_live = False mocked_slide_controller.is_live = False
media_env.media_controller.current_media_players = {'media player': mocked_media_player} media_env.media_controller.current_media_players = {'media player': mocked_media_player}
media_env.media_controller.live_hide_timer = MagicMock() media_env.media_controller.live_hide_timer = MagicMock()
media_env.media_controller._define_display = MagicMock(return_value=mocked_display)
media_env.media_controller._media_set_visibility = MagicMock() media_env.media_controller._media_set_visibility = MagicMock()
# WHEN: media_reset() is called # WHEN: media_reset() is called
media_env.media_controller.media_reset(mocked_slide_controller) media_env.media_controller.media_reset(mocked_slide_controller)
# THEN: The display should be shown, media should be hidden and removed # THEN: The display should be shown, media should be hidden and removed
mocked_display.show_display.assert_called_once_with()
media_env.media_controller._media_set_visibility.assert_called_once_with(mocked_slide_controller, False) media_env.media_controller._media_set_visibility.assert_called_once_with(mocked_slide_controller, False)
assert 'media player' not in media_env.media_controller.current_media_players assert 'media player' not in media_env.media_controller.current_media_players

View File

@ -960,6 +960,7 @@ def test_process_item_transition(mocked_execute, registry, state_media):
slide_controller.song_menu = MagicMock() slide_controller.song_menu = MagicMock()
slide_controller.displays = [MagicMock()] slide_controller.displays = [MagicMock()]
slide_controller.toolbar = MagicMock() slide_controller.toolbar = MagicMock()
slide_controller._current_hide_mode = None
slide_controller.split = 0 slide_controller.split = 0
slide_controller.type_prefix = 'test' slide_controller.type_prefix = 'test'
slide_controller.screen_capture = 'old_capture' slide_controller.screen_capture = 'old_capture'