forked from openlp/openlp
Convert strings from python2 to python3 format
- Strings converted except as noted - Updated projector pjlink test - Simplify lines with multiple references to single variable -------------------------------- lp:~alisonken1/openlp/strings-lib (revision 2665) [SUCCESS] https://ci.openlp.io/job/Branch-01-Pull/1559/ [SUCCESS] https://ci.openlp.io/job/Branch-02-Functional-Tests/1470/ [SUCCESS] https://ci.openlp.io/job/Branch-03-Interface-Tests/1408/ [SUCCESS] https://ci.openlp.io/job/Branch-04a... bzr-revno: 2664
This commit is contained in:
commit
306f027b53
@ -68,9 +68,11 @@ def get_db_path(plugin_name, db_file_name=None):
|
|||||||
:return: The path to the database as type str
|
:return: The path to the database as type str
|
||||||
"""
|
"""
|
||||||
if db_file_name is None:
|
if db_file_name is None:
|
||||||
return 'sqlite:///%s/%s.sqlite' % (AppLocation.get_section_data_path(plugin_name), plugin_name)
|
return 'sqlite:///{path}/{plugin}.sqlite'.format(path=AppLocation.get_section_data_path(plugin_name),
|
||||||
|
plugin=plugin_name)
|
||||||
else:
|
else:
|
||||||
return 'sqlite:///%s/%s' % (AppLocation.get_section_data_path(plugin_name), db_file_name)
|
return 'sqlite:///{path}/{name}'.format(path=AppLocation.get_section_data_path(plugin_name),
|
||||||
|
name=db_file_name)
|
||||||
|
|
||||||
|
|
||||||
def handle_db_error(plugin_name, db_file_name):
|
def handle_db_error(plugin_name, db_file_name):
|
||||||
@ -82,10 +84,10 @@ def handle_db_error(plugin_name, db_file_name):
|
|||||||
:return: None
|
:return: None
|
||||||
"""
|
"""
|
||||||
db_path = get_db_path(plugin_name, db_file_name)
|
db_path = get_db_path(plugin_name, db_file_name)
|
||||||
log.exception('Error loading database: %s', db_path)
|
log.exception('Error loading database: {db}'.format(db=db_path))
|
||||||
critical_error_message_box(translate('OpenLP.Manager', 'Database Error'),
|
critical_error_message_box(translate('OpenLP.Manager', 'Database Error'),
|
||||||
translate('OpenLP.Manager', 'OpenLP cannot load your database.\n\nDatabase: %s')
|
translate('OpenLP.Manager',
|
||||||
% db_path)
|
'OpenLP cannot load your database.\n\nDatabase: {db}').format(db=db_path))
|
||||||
|
|
||||||
|
|
||||||
def init_url(plugin_name, db_file_name=None):
|
def init_url(plugin_name, db_file_name=None):
|
||||||
@ -101,10 +103,11 @@ def init_url(plugin_name, db_file_name=None):
|
|||||||
if db_type == 'sqlite':
|
if db_type == 'sqlite':
|
||||||
db_url = get_db_path(plugin_name, db_file_name)
|
db_url = get_db_path(plugin_name, db_file_name)
|
||||||
else:
|
else:
|
||||||
db_url = '%s://%s:%s@%s/%s' % (db_type, urlquote(settings.value('db username')),
|
db_url = '{type}://{user}:{password}@{host}/{db}'.format(type=db_type,
|
||||||
urlquote(settings.value('db password')),
|
user=urlquote(settings.value('db username')),
|
||||||
urlquote(settings.value('db hostname')),
|
password=urlquote(settings.value('db password')),
|
||||||
urlquote(settings.value('db database')))
|
host=urlquote(settings.value('db hostname')),
|
||||||
|
db=urlquote(settings.value('db database')))
|
||||||
settings.endGroup()
|
settings.endGroup()
|
||||||
return db_url
|
return db_url
|
||||||
|
|
||||||
@ -157,10 +160,10 @@ def upgrade_db(url, upgrade):
|
|||||||
return version, upgrade.__version__
|
return version, upgrade.__version__
|
||||||
version += 1
|
version += 1
|
||||||
try:
|
try:
|
||||||
while hasattr(upgrade, 'upgrade_%d' % version):
|
while hasattr(upgrade, 'upgrade_{version:d}'.format(version=version)):
|
||||||
log.debug('Running upgrade_%d', version)
|
log.debug('Running upgrade_{version:d}'.format(version=version))
|
||||||
try:
|
try:
|
||||||
upgrade_func = getattr(upgrade, 'upgrade_%d' % version)
|
upgrade_func = getattr(upgrade, 'upgrade_{version:d}'.format(version=version))
|
||||||
upgrade_func(session, metadata)
|
upgrade_func(session, metadata)
|
||||||
session.commit()
|
session.commit()
|
||||||
# Update the version number AFTER a commit so that we are sure the previous transaction happened
|
# Update the version number AFTER a commit so that we are sure the previous transaction happened
|
||||||
@ -168,8 +171,8 @@ def upgrade_db(url, upgrade):
|
|||||||
session.commit()
|
session.commit()
|
||||||
version += 1
|
version += 1
|
||||||
except (SQLAlchemyError, DBAPIError):
|
except (SQLAlchemyError, DBAPIError):
|
||||||
log.exception('Could not run database upgrade script "upgrade_%s", upgrade process has been halted.',
|
log.exception('Could not run database upgrade script '
|
||||||
version)
|
'"upgrade_{version:d}", upgrade process has been halted.'.format(version=version))
|
||||||
break
|
break
|
||||||
except (SQLAlchemyError, DBAPIError):
|
except (SQLAlchemyError, DBAPIError):
|
||||||
version_meta = Metadata.populate(key='version', value=int(upgrade.__version__))
|
version_meta = Metadata.populate(key='version', value=int(upgrade.__version__))
|
||||||
@ -242,9 +245,10 @@ class Manager(object):
|
|||||||
critical_error_message_box(
|
critical_error_message_box(
|
||||||
translate('OpenLP.Manager', 'Database Error'),
|
translate('OpenLP.Manager', 'Database Error'),
|
||||||
translate('OpenLP.Manager', 'The database being loaded was created in a more recent version of '
|
translate('OpenLP.Manager', 'The database being loaded was created in a more recent version of '
|
||||||
'OpenLP. The database is version %d, while OpenLP expects version %d. The database will '
|
'OpenLP. The database is version {db_ver}, while OpenLP expects version {db_up}. '
|
||||||
'not be loaded.\n\nDatabase: %s') % (db_ver, up_ver, self.db_url)
|
'The database will not be loaded.\n\nDatabase: {db_name}').format(db_ver=db_ver,
|
||||||
)
|
db_up=up_ver,
|
||||||
|
db_name=self.db_url))
|
||||||
return
|
return
|
||||||
if not session:
|
if not session:
|
||||||
try:
|
try:
|
||||||
@ -460,7 +464,7 @@ class Manager(object):
|
|||||||
raise
|
raise
|
||||||
except InvalidRequestError:
|
except InvalidRequestError:
|
||||||
self.session.rollback()
|
self.session.rollback()
|
||||||
log.exception('Failed to delete %s records', object_class.__name__)
|
log.exception('Failed to delete {name} records'.format(name=object_class.__name__))
|
||||||
return False
|
return False
|
||||||
except:
|
except:
|
||||||
self.session.rollback()
|
self.session.rollback()
|
||||||
|
@ -50,7 +50,8 @@ class FileDialog(QtWidgets.QFileDialog):
|
|||||||
log.info('File not found. Attempting to unquote.')
|
log.info('File not found. Attempting to unquote.')
|
||||||
file = parse.unquote(file)
|
file = parse.unquote(file)
|
||||||
if not os.path.exists(file):
|
if not os.path.exists(file):
|
||||||
log.error('File %s not found.' % file)
|
log.error('File {text} not found.'.format(text=file))
|
||||||
|
# TODO: Test with UiStrings() before converting to python3 strings
|
||||||
QtWidgets.QMessageBox.information(parent, UiStrings().FileNotFound,
|
QtWidgets.QMessageBox.information(parent, UiStrings().FileNotFound,
|
||||||
UiStrings().FileNotFoundMessage % file)
|
UiStrings().FileNotFoundMessage % file)
|
||||||
continue
|
continue
|
||||||
|
@ -396,6 +396,7 @@ from openlp.core.lib.theme import BackgroundType, BackgroundGradientType, Vertic
|
|||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
# TODO: Verify where this is used before converting to python3
|
||||||
HTMLSRC = """
|
HTMLSRC = """
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
@ -564,13 +565,13 @@ def build_html(item, screen, is_live, background, image=None, plugins=None):
|
|||||||
theme_data = item.theme_data
|
theme_data = item.theme_data
|
||||||
# Image generated and poked in
|
# Image generated and poked in
|
||||||
if background:
|
if background:
|
||||||
bgimage_src = 'src="data:image/png;base64,%s"' % background
|
bgimage_src = 'src="data:image/png;base64,{image}"'.format(image=background)
|
||||||
elif item.bg_image_bytes:
|
elif item.bg_image_bytes:
|
||||||
bgimage_src = 'src="data:image/png;base64,%s"' % item.bg_image_bytes
|
bgimage_src = 'src="data:image/png;base64,{image}"'.format(image=item.bg_image_bytes)
|
||||||
else:
|
else:
|
||||||
bgimage_src = 'style="display:none;"'
|
bgimage_src = 'style="display:none;"'
|
||||||
if image:
|
if image:
|
||||||
image_src = 'src="data:image/png;base64,%s"' % image
|
image_src = 'src="data:image/png;base64,{image}"'.format(image=image)
|
||||||
else:
|
else:
|
||||||
image_src = 'style="display:none;"'
|
image_src = 'style="display:none;"'
|
||||||
css_additions = ''
|
css_additions = ''
|
||||||
@ -601,7 +602,7 @@ def webkit_version():
|
|||||||
"""
|
"""
|
||||||
try:
|
try:
|
||||||
webkit_ver = float(QtWebKit.qWebKitVersion())
|
webkit_ver = float(QtWebKit.qWebKitVersion())
|
||||||
log.debug('Webkit version = %s' % webkit_ver)
|
log.debug('Webkit version = {version}'.format(version=webkit_ver))
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
webkit_ver = 0
|
webkit_ver = 0
|
||||||
return webkit_ver
|
return webkit_ver
|
||||||
@ -621,23 +622,25 @@ def build_background_css(item, width):
|
|||||||
if theme.background_type == BackgroundType.to_string(BackgroundType.Transparent):
|
if theme.background_type == BackgroundType.to_string(BackgroundType.Transparent):
|
||||||
background = ''
|
background = ''
|
||||||
elif theme.background_type == BackgroundType.to_string(BackgroundType.Solid):
|
elif theme.background_type == BackgroundType.to_string(BackgroundType.Solid):
|
||||||
background = 'background-color: %s' % theme.background_color
|
background = 'background-color: {theme}'.format(theme=theme.background_color)
|
||||||
else:
|
else:
|
||||||
if theme.background_direction == BackgroundGradientType.to_string(BackgroundGradientType.Horizontal):
|
if theme.background_direction == BackgroundGradientType.to_string(BackgroundGradientType.Horizontal):
|
||||||
background = 'background: -webkit-gradient(linear, left top, left bottom, from(%s), to(%s)) fixed' \
|
background = 'background: -webkit-gradient(linear, left top, left bottom, from({start}), to({end})) ' \
|
||||||
% (theme.background_start_color, theme.background_end_color)
|
'fixed'.format(start=theme.background_start_color, end=theme.background_end_color)
|
||||||
elif theme.background_direction == BackgroundGradientType.to_string(BackgroundGradientType.LeftTop):
|
elif theme.background_direction == BackgroundGradientType.to_string(BackgroundGradientType.LeftTop):
|
||||||
background = 'background: -webkit-gradient(linear, left top, right bottom, from(%s), to(%s)) fixed' \
|
background = 'background: -webkit-gradient(linear, left top, right bottom, from({start}), to({end})) ' \
|
||||||
% (theme.background_start_color, theme.background_end_color)
|
'fixed'.format(start=theme.background_start_color, end=theme.background_end_color)
|
||||||
elif theme.background_direction == BackgroundGradientType.to_string(BackgroundGradientType.LeftBottom):
|
elif theme.background_direction == BackgroundGradientType.to_string(BackgroundGradientType.LeftBottom):
|
||||||
background = 'background: -webkit-gradient(linear, left bottom, right top, from(%s), to(%s)) fixed' \
|
background = 'background: -webkit-gradient(linear, left bottom, right top, from({start}), to({end})) ' \
|
||||||
% (theme.background_start_color, theme.background_end_color)
|
'fixed'.format(start=theme.background_start_color, end=theme.background_end_color)
|
||||||
elif theme.background_direction == BackgroundGradientType.to_string(BackgroundGradientType.Vertical):
|
elif theme.background_direction == BackgroundGradientType.to_string(BackgroundGradientType.Vertical):
|
||||||
background = 'background: -webkit-gradient(linear, left top, right top, from(%s), to(%s)) fixed' % \
|
background = 'background: -webkit-gradient(linear, left top, right top, from({start}), to({end})) ' \
|
||||||
(theme.background_start_color, theme.background_end_color)
|
'fixed'.format(start=theme.background_start_color, end=theme.background_end_color)
|
||||||
else:
|
else:
|
||||||
background = 'background: -webkit-gradient(radial, %s 50%%, 100, %s 50%%, %s, from(%s), to(%s)) fixed'\
|
background = 'background: -webkit-gradient(radial, {width} 50%, 100, {width} 50%, {width}, ' \
|
||||||
% (width, width, width, theme.background_start_color, theme.background_end_color)
|
'from({start}), to({end})) fixed'.format(width=width,
|
||||||
|
start=theme.background_start_color,
|
||||||
|
end=theme.background_end_color)
|
||||||
return background
|
return background
|
||||||
|
|
||||||
|
|
||||||
@ -647,6 +650,7 @@ def build_lyrics_css(item):
|
|||||||
|
|
||||||
:param item: Service Item containing theme and location information
|
:param item: Service Item containing theme and location information
|
||||||
"""
|
"""
|
||||||
|
# TODO: Verify this before converting to python3
|
||||||
style = """
|
style = """
|
||||||
.lyricstable {
|
.lyricstable {
|
||||||
z-index: 5;
|
z-index: 5;
|
||||||
@ -669,12 +673,13 @@ def build_lyrics_css(item):
|
|||||||
lyrics = ''
|
lyrics = ''
|
||||||
lyricsmain = ''
|
lyricsmain = ''
|
||||||
if theme_data and item.main:
|
if theme_data and item.main:
|
||||||
lyricstable = 'left: %spx; top: %spx;' % (item.main.x(), item.main.y())
|
lyricstable = 'left: {left}px; top: {top}px;'.format(left=item.main.x(), top=item.main.y())
|
||||||
lyrics = build_lyrics_format_css(theme_data, item.main.width(), item.main.height())
|
lyrics = build_lyrics_format_css(theme_data, item.main.width(), item.main.height())
|
||||||
lyricsmain += build_lyrics_outline_css(theme_data)
|
lyricsmain += build_lyrics_outline_css(theme_data)
|
||||||
if theme_data.font_main_shadow:
|
if theme_data.font_main_shadow:
|
||||||
lyricsmain += ' text-shadow: %s %spx %spx;' % \
|
lyricsmain += ' text-shadow: {theme} {shadow}px ' \
|
||||||
(theme_data.font_main_shadow_color, theme_data.font_main_shadow_size, theme_data.font_main_shadow_size)
|
'{shadow}px;'.format(theme=theme_data.font_main_shadow_color,
|
||||||
|
shadow=theme_data.font_main_shadow_size)
|
||||||
lyrics_css = style % (lyricstable, lyrics, lyricsmain)
|
lyrics_css = style % (lyricstable, lyrics, lyricsmain)
|
||||||
return lyrics_css
|
return lyrics_css
|
||||||
|
|
||||||
@ -689,7 +694,9 @@ def build_lyrics_outline_css(theme_data):
|
|||||||
size = float(theme_data.font_main_outline_size) / 16
|
size = float(theme_data.font_main_outline_size) / 16
|
||||||
fill_color = theme_data.font_main_color
|
fill_color = theme_data.font_main_color
|
||||||
outline_color = theme_data.font_main_outline_color
|
outline_color = theme_data.font_main_outline_color
|
||||||
return ' -webkit-text-stroke: %sem %s; -webkit-text-fill-color: %s; ' % (size, outline_color, fill_color)
|
return ' -webkit-text-stroke: {size}em {color}; -webkit-text-fill-color: {fill}; '.format(size=size,
|
||||||
|
color=outline_color,
|
||||||
|
fill=fill_color)
|
||||||
return ''
|
return ''
|
||||||
|
|
||||||
|
|
||||||
@ -715,13 +722,21 @@ def build_lyrics_format_css(theme_data, width, height):
|
|||||||
padding_bottom = '0.5em'
|
padding_bottom = '0.5em'
|
||||||
else:
|
else:
|
||||||
padding_bottom = '0'
|
padding_bottom = '0'
|
||||||
lyrics = '%s word-wrap: break-word; ' \
|
lyrics = '{justify} word-wrap: break-word; ' \
|
||||||
'text-align: %s; vertical-align: %s; font-family: %s; ' \
|
'text-align: {align}; vertical-align: {valign}; font-family: {font}; ' \
|
||||||
'font-size: %spt; color: %s; line-height: %d%%; margin: 0;' \
|
'font-size: {size}pt; color: {color}; line-height: {line:d}%; margin: 0;' \
|
||||||
'padding: 0; padding-bottom: %s; padding-left: %spx; width: %spx; height: %spx; ' % \
|
'padding: 0; padding-bottom: {bottom}; padding-left: {left}px; width: {width}px; ' \
|
||||||
(justify, align, valign, theme_data.font_main_name, theme_data.font_main_size,
|
'height: {height}px; '.format(justify=justify,
|
||||||
theme_data.font_main_color, 100 + int(theme_data.font_main_line_adjustment), padding_bottom,
|
align=align,
|
||||||
left_margin, width, height)
|
valign=valign,
|
||||||
|
font=theme_data.font_main_name,
|
||||||
|
size=theme_data.font_main_size,
|
||||||
|
color=theme_data.font_main_color,
|
||||||
|
line=100 + int(theme_data.font_main_line_adjustment),
|
||||||
|
bottom=padding_bottom,
|
||||||
|
left=left_margin,
|
||||||
|
width=width,
|
||||||
|
height=height)
|
||||||
if theme_data.font_main_italics:
|
if theme_data.font_main_italics:
|
||||||
lyrics += 'font-style:italic; '
|
lyrics += 'font-style:italic; '
|
||||||
if theme_data.font_main_bold:
|
if theme_data.font_main_bold:
|
||||||
@ -737,20 +752,21 @@ def build_footer_css(item, height):
|
|||||||
:param height:
|
:param height:
|
||||||
"""
|
"""
|
||||||
style = """
|
style = """
|
||||||
left: %spx;
|
left: {left}px;
|
||||||
bottom: %spx;
|
bottom: {bottom}px;
|
||||||
width: %spx;
|
width: {width}px;
|
||||||
font-family: %s;
|
font-family: {family};
|
||||||
font-size: %spt;
|
font-size: {size}pt;
|
||||||
color: %s;
|
color: {color};
|
||||||
text-align: left;
|
text-align: left;
|
||||||
white-space: %s;
|
white-space: {space};
|
||||||
"""
|
"""
|
||||||
theme = item.theme_data
|
theme = item.theme_data
|
||||||
if not theme or not item.footer:
|
if not theme or not item.footer:
|
||||||
return ''
|
return ''
|
||||||
bottom = height - int(item.footer.y()) - int(item.footer.height())
|
bottom = height - int(item.footer.y()) - int(item.footer.height())
|
||||||
whitespace = 'normal' if Settings().value('themes/wrap footer') else 'nowrap'
|
whitespace = 'normal' if Settings().value('themes/wrap footer') else 'nowrap'
|
||||||
lyrics_html = style % (item.footer.x(), bottom, item.footer.width(),
|
lyrics_html = style.format(left=item.footer.x(), bottom=bottom, width=item.footer.width(),
|
||||||
theme.font_footer_name, theme.font_footer_size, theme.font_footer_color, whitespace)
|
family=theme.font_footer_name, size=theme.font_footer_size,
|
||||||
|
color=theme.font_footer_color, space=whitespace)
|
||||||
return lyrics_html
|
return lyrics_html
|
||||||
|
@ -236,7 +236,7 @@ class ImageManager(QtCore.QObject):
|
|||||||
"""
|
"""
|
||||||
Return the ``QImage`` from the cache. If not present wait for the background thread to process it.
|
Return the ``QImage`` from the cache. If not present wait for the background thread to process it.
|
||||||
"""
|
"""
|
||||||
log.debug('getImage %s' % path)
|
log.debug('getImage {path}'.format(path=path))
|
||||||
image = self._cache[(path, source, width, height)]
|
image = self._cache[(path, source, width, height)]
|
||||||
if image.image is None:
|
if image.image is None:
|
||||||
self._conversion_queue.modify_priority(image, Priority.High)
|
self._conversion_queue.modify_priority(image, Priority.High)
|
||||||
@ -256,7 +256,7 @@ class ImageManager(QtCore.QObject):
|
|||||||
"""
|
"""
|
||||||
Returns the byte string for an image. If not present wait for the background thread to process it.
|
Returns the byte string for an image. If not present wait for the background thread to process it.
|
||||||
"""
|
"""
|
||||||
log.debug('get_image_bytes %s' % path)
|
log.debug('get_image_bytes {path}'.format(path=path))
|
||||||
image = self._cache[(path, source, width, height)]
|
image = self._cache[(path, source, width, height)]
|
||||||
if image.image_bytes is None:
|
if image.image_bytes is None:
|
||||||
self._conversion_queue.modify_priority(image, Priority.Urgent)
|
self._conversion_queue.modify_priority(image, Priority.Urgent)
|
||||||
@ -271,7 +271,7 @@ class ImageManager(QtCore.QObject):
|
|||||||
"""
|
"""
|
||||||
Add image to cache if it is not already there.
|
Add image to cache if it is not already there.
|
||||||
"""
|
"""
|
||||||
log.debug('add_image %s' % path)
|
log.debug('add_image {path}'.format(path=path))
|
||||||
if not (path, source, width, height) in self._cache:
|
if not (path, source, width, height) in self._cache:
|
||||||
image = Image(path, source, background, width, height)
|
image = Image(path, source, background, width, height)
|
||||||
self._cache[(path, source, width, height)] = image
|
self._cache[(path, source, width, height)] = image
|
||||||
|
@ -186,7 +186,7 @@ class MediaManagerItem(QtWidgets.QWidget, RegistryProperties):
|
|||||||
for action in toolbar_actions:
|
for action in toolbar_actions:
|
||||||
if action[0] == StringContent.Preview:
|
if action[0] == StringContent.Preview:
|
||||||
self.toolbar.addSeparator()
|
self.toolbar.addSeparator()
|
||||||
self.toolbar.add_toolbar_action('%s%sAction' % (self.plugin.name, action[0]),
|
self.toolbar.add_toolbar_action('{name}{action}Action'.format(name=self.plugin.name, action=action[0]),
|
||||||
text=self.plugin.get_string(action[1])['title'], icon=action[2],
|
text=self.plugin.get_string(action[1])['title'], icon=action[2],
|
||||||
tooltip=self.plugin.get_string(action[1])['tooltip'],
|
tooltip=self.plugin.get_string(action[1])['tooltip'],
|
||||||
triggers=action[3])
|
triggers=action[3])
|
||||||
@ -200,7 +200,7 @@ class MediaManagerItem(QtWidgets.QWidget, RegistryProperties):
|
|||||||
self.list_view.setSpacing(1)
|
self.list_view.setSpacing(1)
|
||||||
self.list_view.setSelectionMode(QtWidgets.QAbstractItemView.ExtendedSelection)
|
self.list_view.setSelectionMode(QtWidgets.QAbstractItemView.ExtendedSelection)
|
||||||
self.list_view.setAlternatingRowColors(True)
|
self.list_view.setAlternatingRowColors(True)
|
||||||
self.list_view.setObjectName('%sListView' % self.plugin.name)
|
self.list_view.setObjectName('{name}ListView'.format(name=self.plugin.name))
|
||||||
# Add to page_layout
|
# Add to page_layout
|
||||||
self.page_layout.addWidget(self.list_view)
|
self.page_layout.addWidget(self.list_view)
|
||||||
# define and add the context menu
|
# define and add the context menu
|
||||||
@ -212,19 +212,22 @@ class MediaManagerItem(QtWidgets.QWidget, RegistryProperties):
|
|||||||
triggers=self.on_edit_click)
|
triggers=self.on_edit_click)
|
||||||
create_widget_action(self.list_view, separator=True)
|
create_widget_action(self.list_view, separator=True)
|
||||||
create_widget_action(self.list_view,
|
create_widget_action(self.list_view,
|
||||||
'listView%s%sItem' % (self.plugin.name.title(), StringContent.Preview.title()),
|
'listView{plugin}{preview}Item'.format(plugin=self.plugin.name.title(),
|
||||||
|
preview=StringContent.Preview.title()),
|
||||||
text=self.plugin.get_string(StringContent.Preview)['title'],
|
text=self.plugin.get_string(StringContent.Preview)['title'],
|
||||||
icon=':/general/general_preview.png',
|
icon=':/general/general_preview.png',
|
||||||
can_shortcuts=True,
|
can_shortcuts=True,
|
||||||
triggers=self.on_preview_click)
|
triggers=self.on_preview_click)
|
||||||
create_widget_action(self.list_view,
|
create_widget_action(self.list_view,
|
||||||
'listView%s%sItem' % (self.plugin.name.title(), StringContent.Live.title()),
|
'listView{plugin}{live}Item'.format(plugin=self.plugin.name.title(),
|
||||||
|
live=StringContent.Live.title()),
|
||||||
text=self.plugin.get_string(StringContent.Live)['title'],
|
text=self.plugin.get_string(StringContent.Live)['title'],
|
||||||
icon=':/general/general_live.png',
|
icon=':/general/general_live.png',
|
||||||
can_shortcuts=True,
|
can_shortcuts=True,
|
||||||
triggers=self.on_live_click)
|
triggers=self.on_live_click)
|
||||||
create_widget_action(self.list_view,
|
create_widget_action(self.list_view,
|
||||||
'listView%s%sItem' % (self.plugin.name.title(), StringContent.Service.title()),
|
'listView{plugin}{service}Item'.format(plugin=self.plugin.name.title(),
|
||||||
|
service=StringContent.Service.title()),
|
||||||
can_shortcuts=True,
|
can_shortcuts=True,
|
||||||
text=self.plugin.get_string(StringContent.Service)['title'],
|
text=self.plugin.get_string(StringContent.Service)['title'],
|
||||||
icon=':/general/general_add.png',
|
icon=':/general/general_add.png',
|
||||||
@ -232,7 +235,8 @@ class MediaManagerItem(QtWidgets.QWidget, RegistryProperties):
|
|||||||
if self.has_delete_icon:
|
if self.has_delete_icon:
|
||||||
create_widget_action(self.list_view, separator=True)
|
create_widget_action(self.list_view, separator=True)
|
||||||
create_widget_action(self.list_view,
|
create_widget_action(self.list_view,
|
||||||
'listView%s%sItem' % (self.plugin.name.title(), StringContent.Delete.title()),
|
'listView{plugin}{delete}Item'.format(plugin=self.plugin.name.title(),
|
||||||
|
delete=StringContent.Delete.title()),
|
||||||
text=self.plugin.get_string(StringContent.Delete)['title'],
|
text=self.plugin.get_string(StringContent.Delete)['title'],
|
||||||
icon=':/general/general_delete.png',
|
icon=':/general/general_delete.png',
|
||||||
can_shortcuts=True, triggers=self.on_delete_click)
|
can_shortcuts=True, triggers=self.on_delete_click)
|
||||||
@ -313,7 +317,7 @@ class MediaManagerItem(QtWidgets.QWidget, RegistryProperties):
|
|||||||
files = FileDialog.getOpenFileNames(self, self.on_new_prompt,
|
files = FileDialog.getOpenFileNames(self, self.on_new_prompt,
|
||||||
Settings().value(self.settings_section + '/last directory'),
|
Settings().value(self.settings_section + '/last directory'),
|
||||||
self.on_new_file_masks)
|
self.on_new_file_masks)
|
||||||
log.info('New files(s) %s' % files)
|
log.info('New files(s) {files}'.format(files=files))
|
||||||
if files:
|
if files:
|
||||||
self.application.set_busy_cursor()
|
self.application.set_busy_cursor()
|
||||||
self.validate_and_load(files)
|
self.validate_and_load(files)
|
||||||
@ -333,7 +337,8 @@ class MediaManagerItem(QtWidgets.QWidget, RegistryProperties):
|
|||||||
if not error_shown:
|
if not error_shown:
|
||||||
critical_error_message_box(translate('OpenLP.MediaManagerItem', 'Invalid File Type'),
|
critical_error_message_box(translate('OpenLP.MediaManagerItem', 'Invalid File Type'),
|
||||||
translate('OpenLP.MediaManagerItem',
|
translate('OpenLP.MediaManagerItem',
|
||||||
'Invalid File %s.\nSuffix not supported') % file_name)
|
'Invalid File {name}.\n'
|
||||||
|
'Suffix not supported').format(name=file_name))
|
||||||
error_shown = True
|
error_shown = True
|
||||||
else:
|
else:
|
||||||
new_files.append(file_name)
|
new_files.append(file_name)
|
||||||
@ -375,7 +380,8 @@ class MediaManagerItem(QtWidgets.QWidget, RegistryProperties):
|
|||||||
self.load_list(full_list, target_group)
|
self.load_list(full_list, target_group)
|
||||||
last_dir = os.path.split(files[0])[0]
|
last_dir = os.path.split(files[0])[0]
|
||||||
Settings().setValue(self.settings_section + '/last directory', last_dir)
|
Settings().setValue(self.settings_section + '/last directory', last_dir)
|
||||||
Settings().setValue('%s/%s files' % (self.settings_section, self.settings_section), self.get_file_list())
|
Settings().setValue('{section}/{section} files'.format(section=self.settings_section),
|
||||||
|
self.get_file_list())
|
||||||
if duplicates_found:
|
if duplicates_found:
|
||||||
critical_error_message_box(UiStrings().Duplicate,
|
critical_error_message_box(UiStrings().Duplicate,
|
||||||
translate('OpenLP.MediaManagerItem',
|
translate('OpenLP.MediaManagerItem',
|
||||||
@ -550,7 +556,7 @@ class MediaManagerItem(QtWidgets.QWidget, RegistryProperties):
|
|||||||
# Is it possible to process multiple list items to generate
|
# Is it possible to process multiple list items to generate
|
||||||
# multiple service items?
|
# multiple service items?
|
||||||
if self.single_service_item:
|
if self.single_service_item:
|
||||||
log.debug('%s Add requested', self.plugin.name)
|
log.debug('{plugin} Add requested'.format(plugin=self.plugin.name))
|
||||||
self.add_to_service(replace=self.remote_triggered)
|
self.add_to_service(replace=self.remote_triggered)
|
||||||
else:
|
else:
|
||||||
items = self.list_view.selectedIndexes()
|
items = self.list_view.selectedIndexes()
|
||||||
@ -591,7 +597,7 @@ class MediaManagerItem(QtWidgets.QWidget, RegistryProperties):
|
|||||||
translate('OpenLP.MediaManagerItem',
|
translate('OpenLP.MediaManagerItem',
|
||||||
'You must select one or more items.'))
|
'You must select one or more items.'))
|
||||||
else:
|
else:
|
||||||
log.debug('%s Add requested', self.plugin.name)
|
log.debug('{plugin} Add requested'.format(plugin=self.plugin.name))
|
||||||
service_item = self.service_manager.get_service_item()
|
service_item = self.service_manager.get_service_item()
|
||||||
if not service_item:
|
if not service_item:
|
||||||
QtWidgets.QMessageBox.information(self, UiStrings().NISs,
|
QtWidgets.QMessageBox.information(self, UiStrings().NISs,
|
||||||
@ -604,7 +610,8 @@ class MediaManagerItem(QtWidgets.QWidget, RegistryProperties):
|
|||||||
# Turn off the remote edit update message indicator
|
# Turn off the remote edit update message indicator
|
||||||
QtWidgets.QMessageBox.information(self, translate('OpenLP.MediaManagerItem', 'Invalid Service Item'),
|
QtWidgets.QMessageBox.information(self, translate('OpenLP.MediaManagerItem', 'Invalid Service Item'),
|
||||||
translate('OpenLP.MediaManagerItem',
|
translate('OpenLP.MediaManagerItem',
|
||||||
'You must select a %s service item.') % self.title)
|
'You must select a {title} '
|
||||||
|
'service item.').format(title=self.title))
|
||||||
|
|
||||||
def build_service_item(self, item=None, xml_version=False, remote=False, context=ServiceItemContext.Live):
|
def build_service_item(self, item=None, xml_version=False, remote=False, context=ServiceItemContext.Live):
|
||||||
"""
|
"""
|
||||||
|
@ -130,7 +130,7 @@ class Plugin(QtCore.QObject, RegistryProperties):
|
|||||||
:param settings_tab_class: The class name of the plugin's settings tab.
|
:param settings_tab_class: The class name of the plugin's settings tab.
|
||||||
:param version: Defaults to *None*, which means that the same version number is used as OpenLP's version number.
|
:param version: Defaults to *None*, which means that the same version number is used as OpenLP's version number.
|
||||||
"""
|
"""
|
||||||
log.debug('Plugin %s initialised' % name)
|
log.debug('Plugin {plugin} initialised'.format(plugin=name))
|
||||||
super(Plugin, self).__init__()
|
super(Plugin, self).__init__()
|
||||||
self.name = name
|
self.name = name
|
||||||
self.text_strings = {}
|
self.text_strings = {}
|
||||||
@ -154,11 +154,11 @@ class Plugin(QtCore.QObject, RegistryProperties):
|
|||||||
# Append a setting for files in the mediamanager (note not all plugins
|
# Append a setting for files in the mediamanager (note not all plugins
|
||||||
# which have a mediamanager need this).
|
# which have a mediamanager need this).
|
||||||
if media_item_class is not None:
|
if media_item_class is not None:
|
||||||
default_settings['%s/%s files' % (name, name)] = []
|
default_settings['{name}/{name} files'.format(name=name)] = []
|
||||||
# Add settings to the dict of all settings.
|
# Add settings to the dict of all settings.
|
||||||
Settings.extend_default_settings(default_settings)
|
Settings.extend_default_settings(default_settings)
|
||||||
Registry().register_function('%s_add_service_item' % self.name, self.process_add_service_event)
|
Registry().register_function('{name}_add_service_item'.format(name=self.name), self.process_add_service_event)
|
||||||
Registry().register_function('%s_config_updated' % self.name, self.config_update)
|
Registry().register_function('{name}_config_updated'.format(name=self.name), self.config_update)
|
||||||
|
|
||||||
def check_pre_conditions(self):
|
def check_pre_conditions(self):
|
||||||
"""
|
"""
|
||||||
@ -256,7 +256,7 @@ class Plugin(QtCore.QObject, RegistryProperties):
|
|||||||
"""
|
"""
|
||||||
Generic Drag and drop handler triggered from service_manager.
|
Generic Drag and drop handler triggered from service_manager.
|
||||||
"""
|
"""
|
||||||
log.debug('process_add_service_event event called for plugin %s' % self.name)
|
log.debug('process_add_service_event event called for plugin {name}'.format(name=self.name))
|
||||||
if replace:
|
if replace:
|
||||||
self.media_item.on_add_edit_click()
|
self.media_item.on_add_edit_click()
|
||||||
else:
|
else:
|
||||||
|
@ -43,7 +43,7 @@ class PluginManager(RegistryMixin, OpenLPMixin, RegistryProperties):
|
|||||||
super(PluginManager, self).__init__(parent)
|
super(PluginManager, self).__init__(parent)
|
||||||
self.log_info('Plugin manager Initialising')
|
self.log_info('Plugin manager Initialising')
|
||||||
self.base_path = os.path.abspath(AppLocation.get_directory(AppLocation.PluginsDir))
|
self.base_path = os.path.abspath(AppLocation.get_directory(AppLocation.PluginsDir))
|
||||||
self.log_debug('Base path %s ' % self.base_path)
|
self.log_debug('Base path {path}'.format(path=self.base_path))
|
||||||
self.plugins = []
|
self.plugins = []
|
||||||
self.log_info('Plugin manager Initialised')
|
self.log_info('Plugin manager Initialised')
|
||||||
|
|
||||||
@ -73,7 +73,7 @@ class PluginManager(RegistryMixin, OpenLPMixin, RegistryProperties):
|
|||||||
"""
|
"""
|
||||||
start_depth = len(os.path.abspath(self.base_path).split(os.sep))
|
start_depth = len(os.path.abspath(self.base_path).split(os.sep))
|
||||||
present_plugin_dir = os.path.join(self.base_path, 'presentations')
|
present_plugin_dir = os.path.join(self.base_path, 'presentations')
|
||||||
self.log_debug('finding plugins in %s at depth %d' % (self.base_path, start_depth))
|
self.log_debug('finding plugins in {path} at depth {depth:d}'.format(path=self.base_path, depth=start_depth))
|
||||||
for root, dirs, files in os.walk(self.base_path):
|
for root, dirs, files in os.walk(self.base_path):
|
||||||
for name in files:
|
for name in files:
|
||||||
if name.endswith('.py') and not name.startswith('__'):
|
if name.endswith('.py') and not name.startswith('__'):
|
||||||
@ -84,7 +84,9 @@ class PluginManager(RegistryMixin, OpenLPMixin, RegistryProperties):
|
|||||||
break
|
break
|
||||||
module_name = name[:-3]
|
module_name = name[:-3]
|
||||||
# import the modules
|
# import the modules
|
||||||
self.log_debug('Importing %s from %s. Depth %d' % (module_name, root, this_depth))
|
self.log_debug('Importing {name} from {root}. Depth {depth:d}'.format(name=module_name,
|
||||||
|
root=root,
|
||||||
|
depth=this_depth))
|
||||||
try:
|
try:
|
||||||
# Use the "imp" library to try to get around a problem with the PyUNO library which
|
# Use the "imp" library to try to get around a problem with the PyUNO library which
|
||||||
# monkey-patches the __import__ function to do some magic. This causes issues with our tests.
|
# monkey-patches the __import__ function to do some magic. This causes issues with our tests.
|
||||||
@ -93,21 +95,21 @@ class PluginManager(RegistryMixin, OpenLPMixin, RegistryProperties):
|
|||||||
# Then load the module (do the actual import) using the details from find_module()
|
# Then load the module (do the actual import) using the details from find_module()
|
||||||
imp.load_module(module_name, fp, path_name, description)
|
imp.load_module(module_name, fp, path_name, description)
|
||||||
except ImportError as e:
|
except ImportError as e:
|
||||||
self.log_exception('Failed to import module %s on path %s: %s'
|
self.log_exception('Failed to import module {name} on path {path}: '
|
||||||
% (module_name, path, e.args[0]))
|
'{args}'.format(name=module_name, path=path, args=e.args[0]))
|
||||||
plugin_classes = Plugin.__subclasses__()
|
plugin_classes = Plugin.__subclasses__()
|
||||||
plugin_objects = []
|
plugin_objects = []
|
||||||
for p in plugin_classes:
|
for p in plugin_classes:
|
||||||
try:
|
try:
|
||||||
plugin = p()
|
plugin = p()
|
||||||
self.log_debug('Loaded plugin %s' % str(p))
|
self.log_debug('Loaded plugin {plugin}'.format(plugin=str(p)))
|
||||||
plugin_objects.append(plugin)
|
plugin_objects.append(plugin)
|
||||||
except TypeError:
|
except TypeError:
|
||||||
self.log_exception('Failed to load plugin %s' % str(p))
|
self.log_exception('Failed to load plugin {plugin}'.format(plugin=str(p)))
|
||||||
plugins_list = sorted(plugin_objects, key=lambda plugin: plugin.weight)
|
plugins_list = sorted(plugin_objects, key=lambda plugin: plugin.weight)
|
||||||
for plugin in plugins_list:
|
for plugin in plugins_list:
|
||||||
if plugin.check_pre_conditions():
|
if plugin.check_pre_conditions():
|
||||||
self.log_debug('Plugin %s active' % str(plugin.name))
|
self.log_debug('Plugin {plugin} active'.format(plugin=str(plugin.name)))
|
||||||
plugin.set_status()
|
plugin.set_status()
|
||||||
else:
|
else:
|
||||||
plugin.status = PluginStatus.Disabled
|
plugin.status = PluginStatus.Disabled
|
||||||
@ -175,10 +177,11 @@ class PluginManager(RegistryMixin, OpenLPMixin, RegistryProperties):
|
|||||||
Loop through all the plugins and give them an opportunity to initialise themselves.
|
Loop through all the plugins and give them an opportunity to initialise themselves.
|
||||||
"""
|
"""
|
||||||
for plugin in self.plugins:
|
for plugin in self.plugins:
|
||||||
self.log_info('initialising plugins %s in a %s state' % (plugin.name, plugin.is_active()))
|
self.log_info('initialising plugins {plugin} in a {state} state'.format(plugin=plugin.name,
|
||||||
|
state=plugin.is_active()))
|
||||||
if plugin.is_active():
|
if plugin.is_active():
|
||||||
plugin.initialise()
|
plugin.initialise()
|
||||||
self.log_info('Initialisation Complete for %s ' % plugin.name)
|
self.log_info('Initialisation Complete for {plugin}'.format(plugin=plugin.name))
|
||||||
|
|
||||||
def finalise_plugins(self):
|
def finalise_plugins(self):
|
||||||
"""
|
"""
|
||||||
@ -187,7 +190,7 @@ class PluginManager(RegistryMixin, OpenLPMixin, RegistryProperties):
|
|||||||
for plugin in self.plugins:
|
for plugin in self.plugins:
|
||||||
if plugin.is_active():
|
if plugin.is_active():
|
||||||
plugin.finalise()
|
plugin.finalise()
|
||||||
self.log_info('Finalisation Complete for %s ' % plugin.name)
|
self.log_info('Finalisation Complete for {plugin}'.format(plugin=plugin.name))
|
||||||
|
|
||||||
def get_plugin_by_name(self, name):
|
def get_plugin_by_name(self, name):
|
||||||
"""
|
"""
|
||||||
|
@ -107,7 +107,7 @@ class Renderer(OpenLPMixin, RegistryMixin, RegistryProperties):
|
|||||||
|
|
||||||
:param theme_name: The theme name
|
:param theme_name: The theme name
|
||||||
"""
|
"""
|
||||||
self.log_debug("_set_theme with theme %s" % theme_name)
|
self.log_debug("_set_theme with theme {theme}".format(theme=theme_name))
|
||||||
if theme_name not in self._theme_dimensions:
|
if theme_name not in self._theme_dimensions:
|
||||||
theme_data = self.theme_manager.get_theme_data(theme_name)
|
theme_data = self.theme_manager.get_theme_data(theme_name)
|
||||||
main_rect = self.get_main_rectangle(theme_data)
|
main_rect = self.get_main_rectangle(theme_data)
|
||||||
@ -183,7 +183,7 @@ class Renderer(OpenLPMixin, RegistryMixin, RegistryProperties):
|
|||||||
|
|
||||||
:param item_theme_name: The item theme's name.
|
:param item_theme_name: The item theme's name.
|
||||||
"""
|
"""
|
||||||
self.log_debug("set_item_theme with theme %s" % item_theme_name)
|
self.log_debug("set_item_theme with theme {theme}".format(theme=item_theme_name))
|
||||||
self._set_theme(item_theme_name)
|
self._set_theme(item_theme_name)
|
||||||
self.item_theme_name = item_theme_name
|
self.item_theme_name = item_theme_name
|
||||||
|
|
||||||
@ -317,7 +317,7 @@ class Renderer(OpenLPMixin, RegistryMixin, RegistryProperties):
|
|||||||
self.width = screen_size.width()
|
self.width = screen_size.width()
|
||||||
self.height = screen_size.height()
|
self.height = screen_size.height()
|
||||||
self.screen_ratio = self.height / self.width
|
self.screen_ratio = self.height / self.width
|
||||||
self.log_debug('_calculate default %s, %f' % (screen_size, self.screen_ratio))
|
self.log_debug('_calculate default {size}, {ratio:f}'.format(size=screen_size, ratio=self.screen_ratio))
|
||||||
# 90% is start of footer
|
# 90% is start of footer
|
||||||
self.footer_start = int(self.height * 0.90)
|
self.footer_start = int(self.height * 0.90)
|
||||||
|
|
||||||
@ -354,7 +354,7 @@ class Renderer(OpenLPMixin, RegistryMixin, RegistryProperties):
|
|||||||
:param rect_main: The main text block.
|
:param rect_main: The main text block.
|
||||||
:param rect_footer: The footer text block.
|
:param rect_footer: The footer text block.
|
||||||
"""
|
"""
|
||||||
self.log_debug('_set_text_rectangle %s , %s' % (rect_main, rect_footer))
|
self.log_debug('_set_text_rectangle {main} , {footer}'.format(main=rect_main, footer=rect_footer))
|
||||||
self._rect = rect_main
|
self._rect = rect_main
|
||||||
self._rect_footer = rect_footer
|
self._rect_footer = rect_footer
|
||||||
self.page_width = self._rect.width()
|
self.page_width = self._rect.width()
|
||||||
@ -370,6 +370,7 @@ class Renderer(OpenLPMixin, RegistryMixin, RegistryProperties):
|
|||||||
self.web.resize(self.page_width, self.page_height)
|
self.web.resize(self.page_width, self.page_height)
|
||||||
self.web_frame = self.web.page().mainFrame()
|
self.web_frame = self.web.page().mainFrame()
|
||||||
# Adjust width and height to account for shadow. outline done in css.
|
# Adjust width and height to account for shadow. outline done in css.
|
||||||
|
# TODO: Verify before converting to python3 strings
|
||||||
html = """<!DOCTYPE html><html><head><script>
|
html = """<!DOCTYPE html><html><head><script>
|
||||||
function show_text(newtext) {
|
function show_text(newtext) {
|
||||||
var main = document.getElementById('main');
|
var main = document.getElementById('main');
|
||||||
@ -518,7 +519,8 @@ class Renderer(OpenLPMixin, RegistryMixin, RegistryProperties):
|
|||||||
|
|
||||||
:param text: The text to check. It may contain HTML tags.
|
:param text: The text to check. It may contain HTML tags.
|
||||||
"""
|
"""
|
||||||
self.web_frame.evaluateJavaScript('show_text("%s")' % text.replace('\\', '\\\\').replace('\"', '\\\"'))
|
self.web_frame.evaluateJavaScript('show_text'
|
||||||
|
'("{text}")'.format(text=text.replace('\\', '\\\\').replace('\"', '\\\"')))
|
||||||
return self.web_frame.contentsSize().height() <= self.empty_height
|
return self.web_frame.contentsSize().height() <= self.empty_height
|
||||||
|
|
||||||
|
|
||||||
|
@ -78,7 +78,7 @@ class ScreenList(object):
|
|||||||
``number``
|
``number``
|
||||||
The number of the screen, which size has changed.
|
The number of the screen, which size has changed.
|
||||||
"""
|
"""
|
||||||
log.info('screen_resolution_changed %d' % number)
|
log.info('screen_resolution_changed {number:d}'.format(number=number))
|
||||||
for screen in self.screen_list:
|
for screen in self.screen_list:
|
||||||
if number == screen['number']:
|
if number == screen['number']:
|
||||||
new_screen = {
|
new_screen = {
|
||||||
@ -105,7 +105,7 @@ class ScreenList(object):
|
|||||||
"""
|
"""
|
||||||
# Do not log at start up.
|
# Do not log at start up.
|
||||||
if changed_screen != -1:
|
if changed_screen != -1:
|
||||||
log.info('screen_count_changed %d' % self.desktop.screenCount())
|
log.info('screen_count_changed {count:d}'.format(count=self.desktop.screenCount()))
|
||||||
# Remove unplugged screens.
|
# Remove unplugged screens.
|
||||||
for screen in copy.deepcopy(self.screen_list):
|
for screen in copy.deepcopy(self.screen_list):
|
||||||
if screen['number'] == self.desktop.screenCount():
|
if screen['number'] == self.desktop.screenCount():
|
||||||
@ -132,9 +132,11 @@ class ScreenList(object):
|
|||||||
"""
|
"""
|
||||||
screen_list = []
|
screen_list = []
|
||||||
for screen in self.screen_list:
|
for screen in self.screen_list:
|
||||||
screen_name = '%s %d' % (translate('OpenLP.ScreenList', 'Screen'), screen['number'] + 1)
|
screen_name = '{name} {number:d}'.format(name=translate('OpenLP.ScreenList', 'Screen'),
|
||||||
|
number=screen['number'] + 1)
|
||||||
if screen['primary']:
|
if screen['primary']:
|
||||||
screen_name = '%s (%s)' % (screen_name, translate('OpenLP.ScreenList', 'primary'))
|
screen_name = '{name} ({primary})'.format(name=screen_name,
|
||||||
|
primary=translate('OpenLP.ScreenList', 'primary'))
|
||||||
screen_list.append(screen_name)
|
screen_list.append(screen_name)
|
||||||
return screen_list
|
return screen_list
|
||||||
|
|
||||||
@ -152,7 +154,7 @@ class ScreenList(object):
|
|||||||
'size': PyQt5.QtCore.QRect(0, 0, 1024, 768)
|
'size': PyQt5.QtCore.QRect(0, 0, 1024, 768)
|
||||||
}
|
}
|
||||||
"""
|
"""
|
||||||
log.info('Screen %d found with resolution %s' % (screen['number'], screen['size']))
|
log.info('Screen {number:d} found with resolution {size}'.format(number=screen['number'], size=screen['size']))
|
||||||
if screen['primary']:
|
if screen['primary']:
|
||||||
self.current = screen
|
self.current = screen
|
||||||
self.override = copy.deepcopy(self.current)
|
self.override = copy.deepcopy(self.current)
|
||||||
@ -165,7 +167,7 @@ class ScreenList(object):
|
|||||||
|
|
||||||
:param number: The screen number (int).
|
:param number: The screen number (int).
|
||||||
"""
|
"""
|
||||||
log.info('remove_screen %d' % number)
|
log.info('remove_screen {number:d}'.forma(number=number))
|
||||||
for screen in self.screen_list:
|
for screen in self.screen_list:
|
||||||
if screen['number'] == number:
|
if screen['number'] == number:
|
||||||
self.screen_list.remove(screen)
|
self.screen_list.remove(screen)
|
||||||
@ -189,7 +191,7 @@ class ScreenList(object):
|
|||||||
|
|
||||||
:param number: The screen number (int).
|
:param number: The screen number (int).
|
||||||
"""
|
"""
|
||||||
log.debug('set_current_display %s' % number)
|
log.debug('set_current_display {number}'.format(number=number))
|
||||||
if number + 1 > self.display_count:
|
if number + 1 > self.display_count:
|
||||||
self.current = self.screen_list[0]
|
self.current = self.screen_list[0]
|
||||||
else:
|
else:
|
||||||
|
@ -62,9 +62,10 @@ class SearchEdit(QtWidgets.QLineEdit):
|
|||||||
right_padding = self.clear_button.width() + frame_width
|
right_padding = self.clear_button.width() + frame_width
|
||||||
if hasattr(self, 'menu_button'):
|
if hasattr(self, 'menu_button'):
|
||||||
left_padding = self.menu_button.width()
|
left_padding = self.menu_button.width()
|
||||||
stylesheet = 'QLineEdit { padding-left: %spx; padding-right: %spx; } ' % (left_padding, right_padding)
|
stylesheet = 'QLineEdit {{ padding-left:{left}px; padding-right: {right}px; }} '.format(left=left_padding,
|
||||||
|
right=right_padding)
|
||||||
else:
|
else:
|
||||||
stylesheet = 'QLineEdit { padding-right: %spx; } ' % right_padding
|
stylesheet = 'QLineEdit {{ padding-right: {right}px; }} '.format(right=right_padding)
|
||||||
self.setStyleSheet(stylesheet)
|
self.setStyleSheet(stylesheet)
|
||||||
msz = self.minimumSizeHint()
|
msz = self.minimumSizeHint()
|
||||||
self.setMinimumSize(max(msz.width(), self.clear_button.width() + (frame_width * 2) + 2),
|
self.setMinimumSize(max(msz.width(), self.clear_button.width() + (frame_width * 2) + 2),
|
||||||
|
@ -247,7 +247,7 @@ class ServiceItem(RegistryProperties):
|
|||||||
self.renderer.set_item_theme(self.theme)
|
self.renderer.set_item_theme(self.theme)
|
||||||
self.theme_data, self.main, self.footer = self.renderer.pre_render()
|
self.theme_data, self.main, self.footer = self.renderer.pre_render()
|
||||||
if self.service_item_type == ServiceItemType.Text:
|
if self.service_item_type == ServiceItemType.Text:
|
||||||
log.debug('Formatting slides: %s' % self.title)
|
log.debug('Formatting slides: {title}'.format(title=self.title))
|
||||||
# Save rendered pages to this dict. In the case that a slide is used twice we can use the pages saved to
|
# Save rendered pages to this dict. In the case that a slide is used twice we can use the pages saved to
|
||||||
# the dict instead of rendering them again.
|
# the dict instead of rendering them again.
|
||||||
previous_pages = {}
|
previous_pages = {}
|
||||||
@ -270,7 +270,7 @@ class ServiceItem(RegistryProperties):
|
|||||||
elif self.service_item_type == ServiceItemType.Image or self.service_item_type == ServiceItemType.Command:
|
elif self.service_item_type == ServiceItemType.Image or self.service_item_type == ServiceItemType.Command:
|
||||||
pass
|
pass
|
||||||
else:
|
else:
|
||||||
log.error('Invalid value renderer: %s' % self.service_item_type)
|
log.error('Invalid value renderer: {item}'.format(item=self.service_item_type))
|
||||||
self.title = clean_tags(self.title)
|
self.title = clean_tags(self.title)
|
||||||
# The footer should never be None, but to be compatible with a few
|
# The footer should never be None, but to be compatible with a few
|
||||||
# nightly builds between 1.9.4 and 1.9.5, we have to correct this to
|
# nightly builds between 1.9.4 and 1.9.5, we have to correct this to
|
||||||
@ -325,7 +325,8 @@ class ServiceItem(RegistryProperties):
|
|||||||
self.service_item_type = ServiceItemType.Command
|
self.service_item_type = ServiceItemType.Command
|
||||||
# If the item should have a display title but this frame doesn't have one, we make one up
|
# If the item should have a display title but this frame doesn't have one, we make one up
|
||||||
if self.is_capable(ItemCapabilities.HasDisplayTitle) and not display_title:
|
if self.is_capable(ItemCapabilities.HasDisplayTitle) and not display_title:
|
||||||
display_title = translate('OpenLP.ServiceItem', '[slide %d]') % (len(self._raw_frames) + 1)
|
display_title = translate('OpenLP.ServiceItem',
|
||||||
|
'[slide {frame:d}]').format(frame=len(self._raw_frames) + 1)
|
||||||
# Update image path to match servicemanager location if file was loaded from service
|
# Update image path to match servicemanager location if file was loaded from service
|
||||||
if image and not self.has_original_files and self.name == 'presentations':
|
if image and not self.has_original_files and self.name == 'presentations':
|
||||||
file_location = os.path.join(path, file_name)
|
file_location = os.path.join(path, file_name)
|
||||||
@ -392,7 +393,7 @@ class ServiceItem(RegistryProperties):
|
|||||||
:param path: Defaults to *None*. This is the service manager path for things which have their files saved
|
:param path: Defaults to *None*. This is the service manager path for things which have their files saved
|
||||||
with them or None when the saved service is lite and the original file paths need to be preserved.
|
with them or None when the saved service is lite and the original file paths need to be preserved.
|
||||||
"""
|
"""
|
||||||
log.debug('set_from_service called with path %s' % path)
|
log.debug('set_from_service called with path {path}'.format(path=path))
|
||||||
header = service_item['serviceitem']['header']
|
header = service_item['serviceitem']['header']
|
||||||
self.title = header['title']
|
self.title = header['title']
|
||||||
self.name = header['name']
|
self.name = header['name']
|
||||||
@ -608,11 +609,13 @@ class ServiceItem(RegistryProperties):
|
|||||||
start = None
|
start = None
|
||||||
end = None
|
end = None
|
||||||
if self.start_time != 0:
|
if self.start_time != 0:
|
||||||
start = translate('OpenLP.ServiceItem', '<strong>Start</strong>: %s') % \
|
time = str(datetime.timedelta(seconds=self.start_time))
|
||||||
str(datetime.timedelta(seconds=self.start_time))
|
start = translate('OpenLP.ServiceItem',
|
||||||
|
'<strong>Start</strong>: {start}').format(start=time)
|
||||||
if self.media_length != 0:
|
if self.media_length != 0:
|
||||||
end = translate('OpenLP.ServiceItem', '<strong>Length</strong>: %s') % \
|
length = str(datetime.timedelta(seconds=self.media_length // 1000))
|
||||||
str(datetime.timedelta(seconds=self.media_length // 1000))
|
end = translate('OpenLP.ServiceItem', '<strong>Length</strong>: {length}').format(length=length)
|
||||||
|
|
||||||
if not start and not end:
|
if not start and not end:
|
||||||
return ''
|
return ''
|
||||||
elif start and not end:
|
elif start and not end:
|
||||||
@ -620,7 +623,7 @@ class ServiceItem(RegistryProperties):
|
|||||||
elif not start and end:
|
elif not start and end:
|
||||||
return end
|
return end
|
||||||
else:
|
else:
|
||||||
return '%s <br>%s' % (start, end)
|
return '{start} <br>{end}'.format(start=start, end=end)
|
||||||
|
|
||||||
def update_theme(self, theme):
|
def update_theme(self, theme):
|
||||||
"""
|
"""
|
||||||
|
@ -427,7 +427,7 @@ class ThemeXML(object):
|
|||||||
try:
|
try:
|
||||||
theme_xml = objectify.fromstring(xml)
|
theme_xml = objectify.fromstring(xml)
|
||||||
except etree.XMLSyntaxError:
|
except etree.XMLSyntaxError:
|
||||||
log.exception('Invalid xml %s', xml)
|
log.exception('Invalid xml {text}'.format(text=xml))
|
||||||
return
|
return
|
||||||
xml_iter = theme_xml.getiterator()
|
xml_iter = theme_xml.getiterator()
|
||||||
for element in xml_iter:
|
for element in xml_iter:
|
||||||
@ -513,6 +513,7 @@ class ThemeXML(object):
|
|||||||
theme_strings = []
|
theme_strings = []
|
||||||
for key in dir(self):
|
for key in dir(self):
|
||||||
if key[0:1] != '_':
|
if key[0:1] != '_':
|
||||||
|
# TODO: Verify spacing format before converting to python3 string
|
||||||
theme_strings.append('%30s: %s' % (key, getattr(self, key)))
|
theme_strings.append('%30s: %s' % (key, getattr(self, key)))
|
||||||
return '\n'.join(theme_strings)
|
return '\n'.join(theme_strings)
|
||||||
|
|
||||||
|
@ -165,7 +165,7 @@ def create_button(parent, name, **kwargs):
|
|||||||
kwargs.setdefault('icon', ':/services/service_down.png')
|
kwargs.setdefault('icon', ':/services/service_down.png')
|
||||||
kwargs.setdefault('tooltip', translate('OpenLP.Ui', 'Move selection down one position.'))
|
kwargs.setdefault('tooltip', translate('OpenLP.Ui', 'Move selection down one position.'))
|
||||||
else:
|
else:
|
||||||
log.warning('The role "%s" is not defined in create_push_button().', role)
|
log.warning('The role "{role}" is not defined in create_push_button().'.format(role=role))
|
||||||
if kwargs.pop('btn_class', '') == 'toolbutton':
|
if kwargs.pop('btn_class', '') == 'toolbutton':
|
||||||
button = QtWidgets.QToolButton(parent)
|
button = QtWidgets.QToolButton(parent)
|
||||||
else:
|
else:
|
||||||
@ -183,7 +183,7 @@ def create_button(parent, name, **kwargs):
|
|||||||
button.clicked.connect(kwargs.pop('click'))
|
button.clicked.connect(kwargs.pop('click'))
|
||||||
for key in list(kwargs.keys()):
|
for key in list(kwargs.keys()):
|
||||||
if key not in ['text', 'icon', 'tooltip', 'click']:
|
if key not in ['text', 'icon', 'tooltip', 'click']:
|
||||||
log.warning('Parameter %s was not consumed in create_button().', key)
|
log.warning('Parameter {key} was not consumed in create_button().'.format(key=key))
|
||||||
return button
|
return button
|
||||||
|
|
||||||
|
|
||||||
@ -270,7 +270,7 @@ def create_action(parent, name, **kwargs):
|
|||||||
action.triggered.connect(kwargs.pop('triggers'))
|
action.triggered.connect(kwargs.pop('triggers'))
|
||||||
for key in list(kwargs.keys()):
|
for key in list(kwargs.keys()):
|
||||||
if key not in ['text', 'icon', 'tooltip', 'statustip', 'checked', 'can_shortcuts', 'category', 'triggers']:
|
if key not in ['text', 'icon', 'tooltip', 'statustip', 'checked', 'can_shortcuts', 'category', 'triggers']:
|
||||||
log.warning('Parameter %s was not consumed in create_action().' % key)
|
log.warning('Parameter {key} was not consumed in create_action().'.format(key=key))
|
||||||
return action
|
return action
|
||||||
|
|
||||||
|
|
||||||
|
@ -133,37 +133,37 @@ def get_web_page(url, header=None, update_openlp=False):
|
|||||||
time.sleep(0.1)
|
time.sleep(0.1)
|
||||||
try:
|
try:
|
||||||
page = urllib.request.urlopen(req, timeout=CONNECTION_TIMEOUT)
|
page = urllib.request.urlopen(req, timeout=CONNECTION_TIMEOUT)
|
||||||
log.debug('Downloaded page {}'.format(page.geturl()))
|
log.debug('Downloaded page {text}'.format(text=page.geturl()))
|
||||||
break
|
break
|
||||||
except urllib.error.URLError as err:
|
except urllib.error.URLError as err:
|
||||||
log.exception('URLError on {}'.format(url))
|
log.exception('URLError on {text}'.format(text=url))
|
||||||
log.exception('URLError: {}'.format(err.reason))
|
log.exception('URLError: {text}'.format(text=err.reason))
|
||||||
page = None
|
page = None
|
||||||
if retries > CONNECTION_RETRIES:
|
if retries > CONNECTION_RETRIES:
|
||||||
raise
|
raise
|
||||||
except socket.timeout:
|
except socket.timeout:
|
||||||
log.exception('Socket timeout: {}'.format(url))
|
log.exception('Socket timeout: {text}'.format(text=url))
|
||||||
page = None
|
page = None
|
||||||
if retries > CONNECTION_RETRIES:
|
if retries > CONNECTION_RETRIES:
|
||||||
raise
|
raise
|
||||||
except socket.gaierror:
|
except socket.gaierror:
|
||||||
log.exception('Socket gaierror: {}'.format(url))
|
log.exception('Socket gaierror: {text}'.format(text=url))
|
||||||
page = None
|
page = None
|
||||||
if retries > CONNECTION_RETRIES:
|
if retries > CONNECTION_RETRIES:
|
||||||
raise
|
raise
|
||||||
except ConnectionRefusedError:
|
except ConnectionRefusedError:
|
||||||
log.exception('ConnectionRefused: {}'.format(url))
|
log.exception('ConnectionRefused: {text}'.format(text=url))
|
||||||
page = None
|
page = None
|
||||||
if retries > CONNECTION_RETRIES:
|
if retries > CONNECTION_RETRIES:
|
||||||
raise
|
raise
|
||||||
break
|
break
|
||||||
except ConnectionError:
|
except ConnectionError:
|
||||||
log.exception('Connection error: {}'.format(url))
|
log.exception('Connection error: {text}'.format(text=url))
|
||||||
page = None
|
page = None
|
||||||
if retries > CONNECTION_RETRIES:
|
if retries > CONNECTION_RETRIES:
|
||||||
raise
|
raise
|
||||||
except HTTPException:
|
except HTTPException:
|
||||||
log.exception('HTTPException error: {}'.format(url))
|
log.exception('HTTPException error: {text}'.format(text=url))
|
||||||
page = None
|
page = None
|
||||||
if retries > CONNECTION_RETRIES:
|
if retries > CONNECTION_RETRIES:
|
||||||
raise
|
raise
|
||||||
@ -173,7 +173,7 @@ def get_web_page(url, header=None, update_openlp=False):
|
|||||||
if update_openlp:
|
if update_openlp:
|
||||||
Registry().get('application').process_events()
|
Registry().get('application').process_events()
|
||||||
if not page:
|
if not page:
|
||||||
log.exception('{} could not be downloaded'.format(url))
|
log.exception('{text} could not be downloaded'.format(text=url))
|
||||||
return None
|
return None
|
||||||
log.debug(page)
|
log.debug(page)
|
||||||
return page
|
return page
|
||||||
|
@ -112,7 +112,7 @@ class TestPJLink(TestCase):
|
|||||||
@patch.object(pjlink_test, 'projectorReceivedData')
|
@patch.object(pjlink_test, 'projectorReceivedData')
|
||||||
def projector_process_lamp_test(self, mock_projectorReceivedData):
|
def projector_process_lamp_test(self, mock_projectorReceivedData):
|
||||||
"""
|
"""
|
||||||
Test setting lamp on/off and hours
|
Test status lamp on/off and hours
|
||||||
"""
|
"""
|
||||||
# GIVEN: Test object
|
# GIVEN: Test object
|
||||||
pjlink = pjlink_test
|
pjlink = pjlink_test
|
||||||
@ -129,7 +129,7 @@ class TestPJLink(TestCase):
|
|||||||
@patch.object(pjlink_test, 'projectorReceivedData')
|
@patch.object(pjlink_test, 'projectorReceivedData')
|
||||||
def projector_process_multiple_lamp_test(self, mock_projectorReceivedData):
|
def projector_process_multiple_lamp_test(self, mock_projectorReceivedData):
|
||||||
"""
|
"""
|
||||||
Test setting multiple lamp on/off and hours
|
Test status multiple lamp on/off and hours
|
||||||
"""
|
"""
|
||||||
# GIVEN: Test object
|
# GIVEN: Test object
|
||||||
pjlink = pjlink_test
|
pjlink = pjlink_test
|
||||||
@ -156,7 +156,7 @@ class TestPJLink(TestCase):
|
|||||||
@patch.object(pjlink_test, 'projectorReceivedData')
|
@patch.object(pjlink_test, 'projectorReceivedData')
|
||||||
def projector_process_power_on_test(self, mock_projectorReceivedData):
|
def projector_process_power_on_test(self, mock_projectorReceivedData):
|
||||||
"""
|
"""
|
||||||
Test setting power to ON
|
Test status power to ON
|
||||||
"""
|
"""
|
||||||
# GIVEN: Test object and preset
|
# GIVEN: Test object and preset
|
||||||
pjlink = pjlink_test
|
pjlink = pjlink_test
|
||||||
@ -171,7 +171,7 @@ class TestPJLink(TestCase):
|
|||||||
@patch.object(pjlink_test, 'projectorReceivedData')
|
@patch.object(pjlink_test, 'projectorReceivedData')
|
||||||
def projector_process_power_off_test(self, mock_projectorReceivedData):
|
def projector_process_power_off_test(self, mock_projectorReceivedData):
|
||||||
"""
|
"""
|
||||||
Test setting power to STANDBY
|
Test status power to STANDBY
|
||||||
"""
|
"""
|
||||||
# GIVEN: Test object and preset
|
# GIVEN: Test object and preset
|
||||||
pjlink = pjlink_test
|
pjlink = pjlink_test
|
||||||
@ -182,3 +182,71 @@ class TestPJLink(TestCase):
|
|||||||
|
|
||||||
# THEN: Power should be set to STANDBY
|
# THEN: Power should be set to STANDBY
|
||||||
self.assertEquals(pjlink.power, S_STANDBY, 'Power should have been set to STANDBY')
|
self.assertEquals(pjlink.power, S_STANDBY, 'Power should have been set to STANDBY')
|
||||||
|
|
||||||
|
@patch.object(pjlink_test, 'projectorUpdateIcons')
|
||||||
|
def projector_process_avmt_closed_unmuted_test(self, mock_projectorReceivedData):
|
||||||
|
"""
|
||||||
|
Test avmt status shutter closed and audio muted
|
||||||
|
"""
|
||||||
|
# GIVEN: Test object
|
||||||
|
pjlink = pjlink_test
|
||||||
|
pjlink.shutter = False
|
||||||
|
pjlink.mute = True
|
||||||
|
|
||||||
|
# WHEN: Called with setting shutter closed and mute off
|
||||||
|
pjlink.process_avmt('11')
|
||||||
|
|
||||||
|
# THEN: Shutter should be True and mute should be False
|
||||||
|
self.assertTrue(pjlink.shutter, 'Shutter should have been set to closed')
|
||||||
|
self.assertFalse(pjlink.mute, 'Audio should be off')
|
||||||
|
|
||||||
|
@patch.object(pjlink_test, 'projectorUpdateIcons')
|
||||||
|
def projector_process_avmt_open_muted_test(self, mock_projectorReceivedData):
|
||||||
|
"""
|
||||||
|
Test avmt status shutter open and mute on
|
||||||
|
"""
|
||||||
|
# GIVEN: Test object
|
||||||
|
pjlink = pjlink_test
|
||||||
|
pjlink.shutter = True
|
||||||
|
pjlink.mute = False
|
||||||
|
|
||||||
|
# WHEN: Called with setting shutter closed and mute on
|
||||||
|
pjlink.process_avmt('21')
|
||||||
|
|
||||||
|
# THEN: Shutter should be closed and mute should be True
|
||||||
|
self.assertFalse(pjlink.shutter, 'Shutter should have been set to closed')
|
||||||
|
self.assertTrue(pjlink.mute, 'Audio should be off')
|
||||||
|
|
||||||
|
@patch.object(pjlink_test, 'projectorUpdateIcons')
|
||||||
|
def projector_process_avmt_open_unmuted_test(self, mock_projectorReceivedData):
|
||||||
|
"""
|
||||||
|
Test avmt status shutter open and mute off off
|
||||||
|
"""
|
||||||
|
# GIVEN: Test object
|
||||||
|
pjlink = pjlink_test
|
||||||
|
pjlink.shutter = True
|
||||||
|
pjlink.mute = True
|
||||||
|
|
||||||
|
# WHEN: Called with setting shutter to closed and mute on
|
||||||
|
pjlink.process_avmt('30')
|
||||||
|
|
||||||
|
# THEN: Shutter should be closed and mute should be True
|
||||||
|
self.assertFalse(pjlink.shutter, 'Shutter should have been set to open')
|
||||||
|
self.assertFalse(pjlink.mute, 'Audio should be on')
|
||||||
|
|
||||||
|
@patch.object(pjlink_test, 'projectorUpdateIcons')
|
||||||
|
def projector_process_avmt_closed_muted_test(self, mock_projectorReceivedData):
|
||||||
|
"""
|
||||||
|
Test avmt status shutter closed and mute off
|
||||||
|
"""
|
||||||
|
# GIVEN: Test object
|
||||||
|
pjlink = pjlink_test
|
||||||
|
pjlink.shutter = False
|
||||||
|
pjlink.mute = False
|
||||||
|
|
||||||
|
# WHEN: Called with setting shutter to closed and mute on
|
||||||
|
pjlink.process_avmt('31')
|
||||||
|
|
||||||
|
# THEN: Shutter should be closed and mute should be True
|
||||||
|
self.assertTrue(pjlink.shutter, 'Shutter should have been set to closed')
|
||||||
|
self.assertTrue(pjlink.mute, 'Audio should be on')
|
||||||
|
Loading…
Reference in New Issue
Block a user