Merge branch 'oo-presenter-screen' into 'master'

Sets PresenterScreen for OpenOffice if EnablePresenterScreen for LibreOffice fails

Closes #806

See merge request openlp/openlp!316
This commit is contained in:
Raoul Snyman 2021-04-15 17:29:49 +00:00
commit 25b67f802d

View File

@ -232,7 +232,10 @@ class ImpressController(PresentationController):
# Get an updateable configuration view # Get an updateable configuration view
impress_conf_props = self.conf_provider.createInstanceWithArguments( impress_conf_props = self.conf_provider.createInstanceWithArguments(
'com.sun.star.configuration.ConfigurationUpdateAccess', properties) 'com.sun.star.configuration.ConfigurationUpdateAccess', properties)
try:
# Get the specific setting for presentation screen # Get the specific setting for presentation screen
# For libre office this is 'EnablePresenterScreen' but for open office 'PresenterScreen'
# So we try the libre office first, and this raises an exception if it doesn't exist
presenter_screen_enabled = impress_conf_props.getHierarchicalPropertyValue( presenter_screen_enabled = impress_conf_props.getHierarchicalPropertyValue(
'Misc/Start/EnablePresenterScreen') 'Misc/Start/EnablePresenterScreen')
# If the presentation screen is enabled we disable it # If the presentation screen is enabled we disable it
@ -243,6 +246,18 @@ class ImpressController(PresentationController):
# so we make a note that it has been disabled, so it can be enabled again on close. # so we make a note that it has been disabled, so it can be enabled again on close.
if set_visible is False: if set_visible is False:
self.presenter_screen_disabled_by_openlp = True self.presenter_screen_disabled_by_openlp = True
except Exception as e:
# same code as above, except using 'PresenterScreen' which is the open office equivalent
if 'UnknownPropertyException' in str(e):
presenter_screen_enabled = impress_conf_props.getHierarchicalPropertyValue(
'Misc/Start/PresenterScreen')
if presenter_screen_enabled != set_visible:
impress_conf_props.setHierarchicalPropertyValue('Misc/Start/PresenterScreen', set_visible)
impress_conf_props.commitChanges()
if set_visible is False:
self.presenter_screen_disabled_by_openlp = True
else:
raise
except Exception as e: except Exception as e:
log.exception(e) log.exception(e)
trace_error_handler(log) trace_error_handler(log)