forked from openlp/openlp
Merge master.
This commit is contained in:
commit
ab88b77f9c
@ -43,7 +43,7 @@ from traceback import format_exception
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, Settings, ScreenList, UiStrings, Registry, check_directory_exists
|
from openlp.core.lib import Settings, ScreenList, UiStrings, Registry, check_directory_exists
|
||||||
from openlp.core.resources import qInitResources
|
from openlp.core.resources import qInitResources
|
||||||
from openlp.core.ui.mainwindow import MainWindow
|
from openlp.core.ui.mainwindow import MainWindow
|
||||||
from openlp.core.ui.firsttimelanguageform import FirstTimeLanguageForm
|
from openlp.core.ui.firsttimelanguageform import FirstTimeLanguageForm
|
||||||
@ -150,16 +150,10 @@ class OpenLP(QtGui.QApplication):
|
|||||||
update_check = Settings().value(u'general/update check')
|
update_check = Settings().value(u'general/update check')
|
||||||
if update_check:
|
if update_check:
|
||||||
VersionThread(self.main_window).start()
|
VersionThread(self.main_window).start()
|
||||||
Receiver.send_message(u'live_display_blank_check')
|
self.main_window.is_display_blank()
|
||||||
self.main_window.app_startup()
|
self.main_window.app_startup()
|
||||||
return self.exec_()
|
return self.exec_()
|
||||||
|
|
||||||
def close_splash_screen(self):
|
|
||||||
"""
|
|
||||||
Close the splash screen when requested.
|
|
||||||
"""
|
|
||||||
self.splash.close()
|
|
||||||
|
|
||||||
def is_already_running(self):
|
def is_already_running(self):
|
||||||
"""
|
"""
|
||||||
Look to see if OpenLP is already running and ask if a 2nd copy
|
Look to see if OpenLP is already running and ask if a 2nd copy
|
||||||
@ -203,6 +197,7 @@ class OpenLP(QtGui.QApplication):
|
|||||||
"""
|
"""
|
||||||
Wrapper to make ProcessEvents visible and named correctly
|
Wrapper to make ProcessEvents visible and named correctly
|
||||||
"""
|
"""
|
||||||
|
log.debug(u'processing event flush')
|
||||||
self.processEvents()
|
self.processEvents()
|
||||||
|
|
||||||
def set_busy_cursor(self):
|
def set_busy_cursor(self):
|
||||||
|
@ -387,7 +387,6 @@ def create_separated_list(stringlist):
|
|||||||
|
|
||||||
from registry import Registry
|
from registry import Registry
|
||||||
from uistrings import UiStrings
|
from uistrings import UiStrings
|
||||||
from eventreceiver import Receiver
|
|
||||||
from screen import ScreenList
|
from screen import ScreenList
|
||||||
from settings import Settings
|
from settings import Settings
|
||||||
from listwidgetwithdnd import ListWidgetWithDnD
|
from listwidgetwithdnd import ListWidgetWithDnD
|
||||||
|
@ -1,253 +0,0 @@
|
|||||||
# -*- coding: utf-8 -*-
|
|
||||||
# vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4
|
|
||||||
|
|
||||||
###############################################################################
|
|
||||||
# OpenLP - Open Source Lyrics Projection #
|
|
||||||
# --------------------------------------------------------------------------- #
|
|
||||||
# Copyright (c) 2008-2013 Raoul Snyman #
|
|
||||||
# Portions copyright (c) 2008-2013 Tim Bentley, Gerald Britton, Jonathan #
|
|
||||||
# Corwin, Samuel Findlay, Michael Gorven, Scott Guerrieri, Matthias Hub, #
|
|
||||||
# Meinert Jordan, Armin Köhler, Erik Lundin, Edwin Lunando, Brian T. Meyer. #
|
|
||||||
# Joshua Miller, Stevan Pettit, Andreas Preikschat, Mattias Põldaru, #
|
|
||||||
# Christian Richter, Philip Ridout, Simon Scudder, Jeffrey Smith, #
|
|
||||||
# Maikel Stuivenberg, Martin Thompson, Jon Tibble, Dave Warnock, #
|
|
||||||
# Frode Woldsund, Martin Zibricky, Patrick Zimmermann #
|
|
||||||
# --------------------------------------------------------------------------- #
|
|
||||||
# This program is free software; you can redistribute it and/or modify it #
|
|
||||||
# under the terms of the GNU General Public License as published by the Free #
|
|
||||||
# Software Foundation; version 2 of the License. #
|
|
||||||
# #
|
|
||||||
# This program is distributed in the hope that it will be useful, but WITHOUT #
|
|
||||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or #
|
|
||||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for #
|
|
||||||
# more details. #
|
|
||||||
# #
|
|
||||||
# You should have received a copy of the GNU General Public License along #
|
|
||||||
# with this program; if not, write to the Free Software Foundation, Inc., 59 #
|
|
||||||
# Temple Place, Suite 330, Boston, MA 02111-1307 USA #
|
|
||||||
###############################################################################
|
|
||||||
"""
|
|
||||||
Provide event handling code for OpenLP
|
|
||||||
"""
|
|
||||||
import logging
|
|
||||||
|
|
||||||
from PyQt4 import QtCore
|
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
|
||||||
|
|
||||||
|
|
||||||
class EventReceiver(QtCore.QObject):
|
|
||||||
"""
|
|
||||||
Class to allow events to be passed from different parts of the system. This
|
|
||||||
is a private class and should not be used directly but rather via the
|
|
||||||
Receiver class.
|
|
||||||
|
|
||||||
**Mainwindow related and generic signals**
|
|
||||||
|
|
||||||
``mainwindow_status_text``
|
|
||||||
Changes the bottom status bar text on the mainwindow.
|
|
||||||
|
|
||||||
``openlp_error_message``
|
|
||||||
Displays a standalone Error Message.
|
|
||||||
|
|
||||||
``openlp_information_message``
|
|
||||||
Displays a standalone Information Message.
|
|
||||||
|
|
||||||
``openlp_version_check``
|
|
||||||
Version has changed so pop up window.
|
|
||||||
|
|
||||||
``openlp_stop_wizard``
|
|
||||||
Stops a wizard before completion.
|
|
||||||
|
|
||||||
**Setting related signals**
|
|
||||||
|
|
||||||
``config_updated``
|
|
||||||
Informs components that the config has changed.
|
|
||||||
|
|
||||||
``config_screen_changed``
|
|
||||||
The display monitor has been changed.
|
|
||||||
|
|
||||||
**Slidecontroller signals**
|
|
||||||
|
|
||||||
``slidecontroller_{live|preview}_next``
|
|
||||||
Moves to the next slide.
|
|
||||||
|
|
||||||
``slidecontroller_{live|preview}_next_noloop``
|
|
||||||
Moves to the next slide without auto advance.
|
|
||||||
|
|
||||||
``slidecontroller_{live|preview}_previous``
|
|
||||||
Moves to the previous slide.
|
|
||||||
|
|
||||||
``slidecontroller_{live|preview}_previous_noloop``
|
|
||||||
Moves to the previous slide, without auto advance.
|
|
||||||
|
|
||||||
``slidecontroller_{live|preview}_set``
|
|
||||||
Moves to a specific slide, by index.
|
|
||||||
|
|
||||||
``slidecontroller_{live|preview}_started``
|
|
||||||
Broadcasts that an item has been made live/previewed.
|
|
||||||
|
|
||||||
``slidecontroller_{live|preview}_change``
|
|
||||||
Informs the slidecontroller that a slide change has occurred and to
|
|
||||||
update itself.
|
|
||||||
|
|
||||||
``slidecontroller_{live|preview}_changed``
|
|
||||||
Broadcasts that the slidecontroller has changed the current slide.
|
|
||||||
|
|
||||||
``slidecontroller_{live|preview}_blank``
|
|
||||||
Request that the output screen is blanked.
|
|
||||||
|
|
||||||
``slidecontroller_{live|preview}_unblank``
|
|
||||||
Request that the output screen is unblanked.
|
|
||||||
|
|
||||||
``slidecontroller_live_spin_delay``
|
|
||||||
Pushes out the loop delay.
|
|
||||||
|
|
||||||
``slidecontroller_update_slide_limits``
|
|
||||||
Updates the slide_limits variable from the saved settings.
|
|
||||||
|
|
||||||
``slidecontroller_live_stop_loop``
|
|
||||||
Stop the loop on the main display.
|
|
||||||
|
|
||||||
**Display signals**
|
|
||||||
|
|
||||||
``update_display_css``
|
|
||||||
CSS has been updated which needs to be changed on the main display.
|
|
||||||
|
|
||||||
**Live Display signals**
|
|
||||||
|
|
||||||
``live_display_hide``
|
|
||||||
Hide the live display.
|
|
||||||
|
|
||||||
``live_display_show``
|
|
||||||
Return the live display.
|
|
||||||
|
|
||||||
``live_display_active``
|
|
||||||
The live display has been made active.
|
|
||||||
|
|
||||||
``live_display_blank_check``
|
|
||||||
Check to see if the blank display message is required.
|
|
||||||
|
|
||||||
**Theme related singlas**
|
|
||||||
|
|
||||||
``theme_update_list``
|
|
||||||
send out message with new themes.
|
|
||||||
|
|
||||||
``theme_update_global``
|
|
||||||
Tell the components we have a new global theme.
|
|
||||||
|
|
||||||
**Plugin specific signals**
|
|
||||||
|
|
||||||
``{plugin}_start``
|
|
||||||
Requests a plugin to start a external program. Path and file have to
|
|
||||||
be provided in the message.
|
|
||||||
|
|
||||||
``{plugin}_first``
|
|
||||||
Requests a plugin to handle a first event.
|
|
||||||
|
|
||||||
``{plugin}_previous``
|
|
||||||
Requests a plugin to handle a previous event.
|
|
||||||
|
|
||||||
``{plugin}_next``
|
|
||||||
Requests a plugin to handle a next event.
|
|
||||||
|
|
||||||
``{plugin}_last``
|
|
||||||
Requests a plugin to handle a last event.
|
|
||||||
|
|
||||||
``{plugin}_slide``
|
|
||||||
Requests a plugin to handle a go to specific slide event.
|
|
||||||
|
|
||||||
``{plugin}_stop``
|
|
||||||
Requests a plugin to handle a stop event.
|
|
||||||
|
|
||||||
``{plugin}_blank``
|
|
||||||
Requests a plugin to handle a blank screen event.
|
|
||||||
|
|
||||||
``{plugin}_unblank``
|
|
||||||
Requests a plugin to handle an unblank screen event.
|
|
||||||
|
|
||||||
``{plugin}_load_list``
|
|
||||||
Tells the the plugin to reload the media manager list.
|
|
||||||
|
|
||||||
``{plugin}_preview``
|
|
||||||
Tells the plugin it's item can be previewed.
|
|
||||||
|
|
||||||
``{plugin}_add_service_item``
|
|
||||||
Ask the plugin to push the selected items to the service item.
|
|
||||||
|
|
||||||
``{plugin}_service_load``
|
|
||||||
Ask the plugin to process an individual service item after it has been
|
|
||||||
loaded.
|
|
||||||
|
|
||||||
``{plugin}_config_updated``
|
|
||||||
The config has changed so tell the plugin about it.
|
|
||||||
|
|
||||||
``alerts_text``
|
|
||||||
Displays an alert message.
|
|
||||||
|
|
||||||
``bibles_nobook``
|
|
||||||
Attempt to find book resulted in no match.
|
|
||||||
|
|
||||||
``remotes_poll_request``
|
|
||||||
Waits for openlp to do something "interesting" and sends a
|
|
||||||
``remotes_poll_response`` signal when it does.
|
|
||||||
|
|
||||||
"""
|
|
||||||
def __init__(self):
|
|
||||||
"""
|
|
||||||
Initialise the event receiver, calling the parent constructor.
|
|
||||||
"""
|
|
||||||
QtCore.QObject.__init__(self)
|
|
||||||
|
|
||||||
def send_message(self, event, msg=None):
|
|
||||||
"""
|
|
||||||
Emit a Qt signal.
|
|
||||||
|
|
||||||
``event``
|
|
||||||
The event to that was sent.
|
|
||||||
|
|
||||||
``msg``
|
|
||||||
Defaults to *None*. The message to send with the event.
|
|
||||||
"""
|
|
||||||
log.debug(u'Event %s passed with payload %s' % (event, msg))
|
|
||||||
self.emit(QtCore.SIGNAL(event), msg)
|
|
||||||
|
|
||||||
|
|
||||||
class Receiver(object):
|
|
||||||
"""
|
|
||||||
Class to allow events to be passed from different parts of the system. This
|
|
||||||
is a static wrapper around the ``EventReceiver`` class. As there is only
|
|
||||||
one instance of it in the system the Qt4 signal/slot architecture can send
|
|
||||||
messages across the system.
|
|
||||||
|
|
||||||
To send a message:
|
|
||||||
``Receiver.send_message(u'<<Message ID>>', data)``
|
|
||||||
|
|
||||||
To receive a Message
|
|
||||||
``QtCore.QObject.connect(
|
|
||||||
Receiver.get_receiver(),
|
|
||||||
QtCore.SIGNAL(u'<<Message ID>>'),
|
|
||||||
<<ACTION>>
|
|
||||||
)``
|
|
||||||
"""
|
|
||||||
__eventreceiver__ = EventReceiver()
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def send_message(event, msg=None):
|
|
||||||
"""
|
|
||||||
Sends a message to the messaging system.
|
|
||||||
|
|
||||||
``event``
|
|
||||||
The event to send.
|
|
||||||
|
|
||||||
``msg``
|
|
||||||
Defaults to *None*. The message to send with the event.
|
|
||||||
"""
|
|
||||||
Receiver.__eventreceiver__.send_message(event, msg)
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def get_receiver():
|
|
||||||
"""
|
|
||||||
Get the global ``__eventreceiver__`` instance.
|
|
||||||
"""
|
|
||||||
return Receiver.__eventreceiver__
|
|
@ -39,7 +39,7 @@ import Queue
|
|||||||
|
|
||||||
from PyQt4 import QtCore
|
from PyQt4 import QtCore
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, Registry, ScreenList, resize_image, image_to_byte
|
from openlp.core.lib import Registry, ScreenList, resize_image, image_to_byte
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
@ -200,7 +200,7 @@ class ImageManager(QtCore.QObject):
|
|||||||
self.image_thread = ImageThread(self)
|
self.image_thread = ImageThread(self)
|
||||||
self._conversion_queue = PriorityQueue()
|
self._conversion_queue = PriorityQueue()
|
||||||
self.stop_manager = False
|
self.stop_manager = False
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'config_updated'), self.process_updates)
|
Registry().register_function(u'config_updated', self.process_updates)
|
||||||
|
|
||||||
def update_display(self):
|
def update_display(self):
|
||||||
"""
|
"""
|
||||||
|
@ -33,7 +33,7 @@ import os
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Receiver
|
from openlp.core.lib import Registry
|
||||||
|
|
||||||
|
|
||||||
class ListWidgetWithDnD(QtGui.QListWidget):
|
class ListWidgetWithDnD(QtGui.QListWidget):
|
||||||
@ -54,8 +54,7 @@ class ListWidgetWithDnD(QtGui.QListWidget):
|
|||||||
"""
|
"""
|
||||||
self.setAcceptDrops(True)
|
self.setAcceptDrops(True)
|
||||||
self.setDragDropMode(QtGui.QAbstractItemView.DragDrop)
|
self.setDragDropMode(QtGui.QAbstractItemView.DragDrop)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'%s_dnd' % self.mimeDataText),
|
Registry().register_function((u'%s_dnd' % self.mimeDataText), self.parent().loadFile)
|
||||||
self.parent().loadFile)
|
|
||||||
|
|
||||||
def mouseMoveEvent(self, event):
|
def mouseMoveEvent(self, event):
|
||||||
"""
|
"""
|
||||||
@ -112,6 +111,6 @@ class ListWidgetWithDnD(QtGui.QListWidget):
|
|||||||
listing = os.listdir(localFile)
|
listing = os.listdir(localFile)
|
||||||
for file in listing:
|
for file in listing:
|
||||||
files.append(os.path.join(localFile, file))
|
files.append(os.path.join(localFile, file))
|
||||||
Receiver.send_message(u'%s_dnd' % self.mimeDataText, files)
|
Registry().execute(u'%s_dnd' % self.mimeDataText, files)
|
||||||
else:
|
else:
|
||||||
event.ignore()
|
event.ignore()
|
||||||
|
@ -35,7 +35,7 @@ import re
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import OpenLPToolbar, ServiceItem, StringContent, Receiver, ListWidgetWithDnD, \
|
from openlp.core.lib import OpenLPToolbar, ServiceItem, StringContent, ListWidgetWithDnD, \
|
||||||
ServiceItemContext, Settings, Registry, UiStrings, build_icon, translate
|
ServiceItemContext, Settings, Registry, UiStrings, build_icon, translate
|
||||||
from openlp.core.lib.searchedit import SearchEdit
|
from openlp.core.lib.searchedit import SearchEdit
|
||||||
from openlp.core.lib.ui import create_widget_action, critical_error_message_box
|
from openlp.core.lib.ui import create_widget_action, critical_error_message_box
|
||||||
@ -116,8 +116,7 @@ class MediaManagerItem(QtGui.QWidget):
|
|||||||
self.setupUi()
|
self.setupUi()
|
||||||
self.retranslateUi()
|
self.retranslateUi()
|
||||||
self.autoSelectId = -1
|
self.autoSelectId = -1
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'%s_service_load' % self.plugin.name),
|
Registry().register_function(u'%s_service_load' % self.plugin.name, self.serviceLoad)
|
||||||
self.serviceLoad)
|
|
||||||
|
|
||||||
def requiredIcons(self):
|
def requiredIcons(self):
|
||||||
"""
|
"""
|
||||||
|
@ -33,7 +33,7 @@ import logging
|
|||||||
|
|
||||||
from PyQt4 import QtCore
|
from PyQt4 import QtCore
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, Settings, Registry, UiStrings
|
from openlp.core.lib import Settings, Registry, UiStrings
|
||||||
from openlp.core.utils import get_application_version
|
from openlp.core.utils import get_application_version
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
@ -171,10 +171,8 @@ class Plugin(QtCore.QObject):
|
|||||||
default_settings[u'%s/%s files' % (name, name)] = []
|
default_settings[u'%s/%s files' % (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)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'%s_add_service_item' % self.name),
|
Registry().register_function(u'%s_add_service_item' % self.name, self.processAddServiceEvent)
|
||||||
self.processAddServiceEvent)
|
Registry().register_function(u'%s_config_updated' % self.name, self.config_update)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'%s_config_updated' % self.name),
|
|
||||||
self.configUpdated)
|
|
||||||
|
|
||||||
def checkPreConditions(self):
|
def checkPreConditions(self):
|
||||||
"""
|
"""
|
||||||
@ -403,7 +401,7 @@ class Plugin(QtCore.QObject):
|
|||||||
"""
|
"""
|
||||||
return u''
|
return u''
|
||||||
|
|
||||||
def configUpdated(self):
|
def config_update(self):
|
||||||
"""
|
"""
|
||||||
The plugin's config has changed
|
The plugin's config has changed
|
||||||
"""
|
"""
|
||||||
|
@ -59,15 +59,19 @@ class Registry(object):
|
|||||||
log.info(u'Registry Initialising')
|
log.info(u'Registry Initialising')
|
||||||
registry = cls()
|
registry = cls()
|
||||||
registry.service_list = {}
|
registry.service_list = {}
|
||||||
|
registry.functions_list = {}
|
||||||
registry.running_under_test = False
|
registry.running_under_test = False
|
||||||
# Allow the tests to remove Registry entries but not the live system
|
# Allow the tests to remove Registry entries but not the live system
|
||||||
if u'nosetest' in sys.argv[0]:
|
if u'nose' in sys.argv[0]:
|
||||||
registry.running_under_test = True
|
registry.running_under_test = True
|
||||||
return registry
|
return registry
|
||||||
|
|
||||||
def get(self, key):
|
def get(self, key):
|
||||||
"""
|
"""
|
||||||
Extracts the registry value from the list based on the key passed in
|
Extracts the registry value from the list based on the key passed in
|
||||||
|
|
||||||
|
``key``
|
||||||
|
The service to be retrieved.
|
||||||
"""
|
"""
|
||||||
if key in self.service_list:
|
if key in self.service_list:
|
||||||
return self.service_list[key]
|
return self.service_list[key]
|
||||||
@ -78,6 +82,12 @@ class Registry(object):
|
|||||||
def register(self, key, reference):
|
def register(self, key, reference):
|
||||||
"""
|
"""
|
||||||
Registers a component against a key.
|
Registers a component against a key.
|
||||||
|
|
||||||
|
``key``
|
||||||
|
The service to be created this is usually a major class like "renderer" or "main_window" .
|
||||||
|
|
||||||
|
``reference``
|
||||||
|
The service address to be saved.
|
||||||
"""
|
"""
|
||||||
if key in self.service_list:
|
if key in self.service_list:
|
||||||
log.error(u'Duplicate service exception %s' % key)
|
log.error(u'Duplicate service exception %s' % key)
|
||||||
@ -88,11 +98,73 @@ class Registry(object):
|
|||||||
def remove(self, key):
|
def remove(self, key):
|
||||||
"""
|
"""
|
||||||
Removes the registry value from the list based on the key passed in
|
Removes the registry value from the list based on the key passed in
|
||||||
(Only valid and active for testing framework)
|
(Only valid and active for testing framework).
|
||||||
|
|
||||||
|
``key``
|
||||||
|
The service to be deleted.
|
||||||
"""
|
"""
|
||||||
if self.running_under_test is False:
|
if self.running_under_test is False:
|
||||||
log.error(u'Invalid Method call for key %s' % key)
|
log.error(u'Invalid Method call for key %s' % key)
|
||||||
raise KeyError(u'Invalid Method call for key %s' % key)
|
raise KeyError(u'Invalid Method call for key %s' % key)
|
||||||
return
|
|
||||||
if key in self.service_list:
|
if key in self.service_list:
|
||||||
del self.service_list[key]
|
del self.service_list[key]
|
||||||
|
|
||||||
|
def register_function(self, event, function):
|
||||||
|
"""
|
||||||
|
Register an event and associated function to be called
|
||||||
|
|
||||||
|
``event``
|
||||||
|
The function description like "config_updated" or "live_display_hide" where a number of places in the
|
||||||
|
code will/may need to respond to a single action and the caller does not need to understand or know about
|
||||||
|
the recipients.
|
||||||
|
|
||||||
|
``function``
|
||||||
|
The function to be called when the event happens.
|
||||||
|
"""
|
||||||
|
if event in self.functions_list:
|
||||||
|
self.functions_list[event].append(function)
|
||||||
|
else:
|
||||||
|
self.functions_list[event] = [function]
|
||||||
|
|
||||||
|
def remove_function(self, event, function):
|
||||||
|
"""
|
||||||
|
Remove an event and associated handler
|
||||||
|
|
||||||
|
``event``
|
||||||
|
The function description..
|
||||||
|
|
||||||
|
``function``
|
||||||
|
The function to be called when the event happens.
|
||||||
|
"""
|
||||||
|
if self.running_under_test is False:
|
||||||
|
log.error(u'Invalid Method call for key %s' % event)
|
||||||
|
raise KeyError(u'Invalid Method call for key %s' % event)
|
||||||
|
if event in self.functions_list:
|
||||||
|
self.functions_list[event].remove(function)
|
||||||
|
|
||||||
|
def execute(self, event, *args, **kwargs):
|
||||||
|
"""
|
||||||
|
Execute all the handlers associated with the event and return an array of results.
|
||||||
|
|
||||||
|
``event``
|
||||||
|
The function to be processed
|
||||||
|
|
||||||
|
``*args``
|
||||||
|
Parameters to be passed to the function.
|
||||||
|
|
||||||
|
``*kwargs``
|
||||||
|
Parameters to be passed to the function.
|
||||||
|
"""
|
||||||
|
results = []
|
||||||
|
if event in self.functions_list:
|
||||||
|
for function in self.functions_list[event]:
|
||||||
|
try:
|
||||||
|
result = function(*args, **kwargs)
|
||||||
|
if result:
|
||||||
|
results.append(result)
|
||||||
|
except TypeError:
|
||||||
|
# Who has called me can help in debugging
|
||||||
|
import inspect
|
||||||
|
log.debug(inspect.currentframe().f_back.f_locals)
|
||||||
|
log.exception(u'Exception for function %s', function)
|
||||||
|
return results
|
||||||
|
@ -31,8 +31,8 @@ import logging
|
|||||||
|
|
||||||
from PyQt4 import QtGui, QtCore, QtWebKit
|
from PyQt4 import QtGui, QtCore, QtWebKit
|
||||||
|
|
||||||
from openlp.core.lib import FormattingTags, ImageSource, ItemCapabilities, Receiver, Registry, ScreenList, \
|
from openlp.core.lib import FormattingTags, ImageSource, ItemCapabilities, Registry, ScreenList, ServiceItem, \
|
||||||
ServiceItem, expand_tags, build_lyrics_format_css, build_lyrics_outline_css
|
expand_tags, build_lyrics_format_css, build_lyrics_outline_css
|
||||||
from openlp.core.lib.theme import ThemeLevel
|
from openlp.core.lib.theme import ThemeLevel
|
||||||
from openlp.core.ui import MainDisplay
|
from openlp.core.ui import MainDisplay
|
||||||
|
|
||||||
@ -80,7 +80,7 @@ class Renderer(object):
|
|||||||
self.display.setup()
|
self.display.setup()
|
||||||
self._theme_dimensions = {}
|
self._theme_dimensions = {}
|
||||||
self._calculate_default()
|
self._calculate_default()
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'theme_update_global'), self.set_global_theme)
|
Registry().register_function(u'theme_update_global', self.set_global_theme)
|
||||||
self.web = QtWebKit.QWebView()
|
self.web = QtWebKit.QWebView()
|
||||||
self.web.setVisible(False)
|
self.web.setVisible(False)
|
||||||
self.web_frame = self.web.page().mainFrame()
|
self.web_frame = self.web.page().mainFrame()
|
||||||
@ -602,7 +602,7 @@ class Renderer(object):
|
|||||||
previous_raw = u''
|
previous_raw = u''
|
||||||
# Stop here as the theme line count was requested.
|
# Stop here as the theme line count was requested.
|
||||||
if self.force_page:
|
if self.force_page:
|
||||||
Receiver.send_message(u'theme_line_count', index + 1)
|
Registry().execute(u'theme_line_count', index + 1)
|
||||||
break
|
break
|
||||||
else:
|
else:
|
||||||
continue
|
continue
|
||||||
|
@ -35,7 +35,7 @@ import copy
|
|||||||
|
|
||||||
from PyQt4 import QtCore
|
from PyQt4 import QtCore
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, translate
|
from openlp.core.lib import Registry, translate
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
@ -100,7 +100,7 @@ class ScreenList(object):
|
|||||||
if screen == self.override:
|
if screen == self.override:
|
||||||
self.override = copy.deepcopy(newScreen)
|
self.override = copy.deepcopy(newScreen)
|
||||||
self.set_override_display()
|
self.set_override_display()
|
||||||
Receiver.send_message(u'config_screen_changed')
|
Registry().execute(u'config_screen_changed')
|
||||||
break
|
break
|
||||||
|
|
||||||
def screen_count_changed(self, changed_screen=-1):
|
def screen_count_changed(self, changed_screen=-1):
|
||||||
@ -128,7 +128,7 @@ class ScreenList(object):
|
|||||||
# We do not want to send this message at start up.
|
# We do not want to send this message at start up.
|
||||||
if changed_screen != -1:
|
if changed_screen != -1:
|
||||||
# Reload setting tabs to apply possible changes.
|
# Reload setting tabs to apply possible changes.
|
||||||
Receiver.send_message(u'config_screen_changed')
|
Registry().execute(u'config_screen_changed')
|
||||||
|
|
||||||
def get_screen_list(self):
|
def get_screen_list(self):
|
||||||
"""
|
"""
|
||||||
@ -244,7 +244,7 @@ class ScreenList(object):
|
|||||||
Loads the screen size and the monitor number from the settings.
|
Loads the screen size and the monitor number from the settings.
|
||||||
"""
|
"""
|
||||||
from openlp.core.lib import Settings
|
from openlp.core.lib import Settings
|
||||||
# Add the screen settings to the settings dict. This has to be done here due to crycle dependency.
|
# Add the screen settings to the settings dict. This has to be done here due to cyclic dependency.
|
||||||
# Do not do this anywhere else.
|
# Do not do this anywhere else.
|
||||||
screen_settings = {
|
screen_settings = {
|
||||||
u'general/x position': self.current[u'size'].x(),
|
u'general/x position': self.current[u'size'].x(),
|
||||||
|
@ -260,6 +260,7 @@ class Settings(QtCore.QSettings):
|
|||||||
"""
|
"""
|
||||||
Settings.__default_settings__ = dict(default_values.items() + Settings.__default_settings__.items())
|
Settings.__default_settings__ = dict(default_values.items() + Settings.__default_settings__.items())
|
||||||
|
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def set_filename(ini_file):
|
def set_filename(ini_file):
|
||||||
"""
|
"""
|
||||||
|
@ -33,7 +33,7 @@ import logging
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, UiStrings, build_icon, translate
|
from openlp.core.lib import Registry, UiStrings, build_icon, translate
|
||||||
from openlp.core.utils.actions import ActionList
|
from openlp.core.utils.actions import ActionList
|
||||||
|
|
||||||
|
|
||||||
@ -135,8 +135,7 @@ def critical_error_message_box(title=None, message=None, parent=None, question=F
|
|||||||
return QtGui.QMessageBox.critical(parent, UiStrings().Error, message,
|
return QtGui.QMessageBox.critical(parent, UiStrings().Error, message,
|
||||||
QtGui.QMessageBox.StandardButtons(QtGui.QMessageBox.Yes | QtGui.QMessageBox.No))
|
QtGui.QMessageBox.StandardButtons(QtGui.QMessageBox.Yes | QtGui.QMessageBox.No))
|
||||||
data = {u'message': message}
|
data = {u'message': message}
|
||||||
data[u'title'] = title if title else UiStrings().Error
|
return Registry().get(u'main_window').error_message(title if title else UiStrings().Error, message)
|
||||||
return Receiver.send_message(u'openlp_error_message', data)
|
|
||||||
|
|
||||||
|
|
||||||
def create_horizontal_adjusting_combo_box(parent, name):
|
def create_horizontal_adjusting_combo_box(parent, name):
|
||||||
|
@ -36,7 +36,7 @@ import sys
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import SettingsTab, Receiver, Settings, UiStrings, translate, build_icon
|
from openlp.core.lib import Registry, SettingsTab, Settings, UiStrings, translate, build_icon
|
||||||
from openlp.core.utils import AppLocation, format_time, get_images_filter
|
from openlp.core.utils import AppLocation, format_time, get_images_filter
|
||||||
from openlp.core.lib import SlideLimits
|
from openlp.core.lib import SlideLimits
|
||||||
|
|
||||||
@ -397,22 +397,19 @@ class AdvancedTab(SettingsTab):
|
|||||||
if not os.path.exists(self.current_data_path):
|
if not os.path.exists(self.current_data_path):
|
||||||
log.error(u'Data path not found %s' % self.current_data_path)
|
log.error(u'Data path not found %s' % self.current_data_path)
|
||||||
answer = QtGui.QMessageBox.critical(self,
|
answer = QtGui.QMessageBox.critical(self,
|
||||||
translate('OpenLP.AdvancedTab',
|
translate('OpenLP.AdvancedTab', 'Data Directory Error'),
|
||||||
'Data Directory Error'),
|
translate('OpenLP.AdvancedTab', 'OpenLP data directory was not found\n\n%s\n\n'
|
||||||
translate('OpenLP.AdvancedTab',
|
|
||||||
'OpenLP data directory was not found\n\n%s\n\n'
|
|
||||||
'This data directory was previously changed from the OpenLP '
|
'This data directory was previously changed from the OpenLP '
|
||||||
'default location. If the new location was on removable '
|
'default location. If the new location was on removable '
|
||||||
'media, that media needs to be made available.\n\n'
|
'media, that media needs to be made available.\n\n'
|
||||||
'Click "No" to stop loading OpenLP. allowing you to fix '
|
'Click "No" to stop loading OpenLP. allowing you to fix the the problem.\n\n'
|
||||||
'the the problem.\n\n'
|
|
||||||
'Click "Yes" to reset the data directory to the default '
|
'Click "Yes" to reset the data directory to the default '
|
||||||
'location.').replace('%s', self.current_data_path),
|
'location.').replace('%s', self.current_data_path),
|
||||||
QtGui.QMessageBox.StandardButtons(QtGui.QMessageBox.Yes | QtGui.QMessageBox.No),
|
QtGui.QMessageBox.StandardButtons(QtGui.QMessageBox.Yes | QtGui.QMessageBox.No),
|
||||||
QtGui.QMessageBox.No)
|
QtGui.QMessageBox.No)
|
||||||
if answer == QtGui.QMessageBox.No:
|
if answer == QtGui.QMessageBox.No:
|
||||||
log.info(u'User requested termination')
|
log.info(u'User requested termination')
|
||||||
Receiver.send_message(u'cleanup')
|
self.main_window.clean_up()
|
||||||
sys.exit()
|
sys.exit()
|
||||||
# Set data location to default.
|
# Set data location to default.
|
||||||
settings.remove(u'advanced/data path')
|
settings.remove(u'advanced/data path')
|
||||||
@ -455,9 +452,9 @@ class AdvancedTab(SettingsTab):
|
|||||||
settings.setValue(u'slide limits', self.slide_limits)
|
settings.setValue(u'slide limits', self.slide_limits)
|
||||||
settings.endGroup()
|
settings.endGroup()
|
||||||
if self.display_changed:
|
if self.display_changed:
|
||||||
Receiver.send_message(u'config_screen_changed')
|
Registry().execute(u'config_screen_changed')
|
||||||
self.display_changed = False
|
self.display_changed = False
|
||||||
Receiver.send_message(u'slidecontroller_update_slide_limits')
|
Registry().execute(u'slidecontroller_update_slide_limits')
|
||||||
|
|
||||||
def cancel(self):
|
def cancel(self):
|
||||||
"""
|
"""
|
||||||
@ -573,7 +570,7 @@ class AdvancedTab(SettingsTab):
|
|||||||
# Check if data already exists here.
|
# Check if data already exists here.
|
||||||
self.check_data_overwrite(new_data_path)
|
self.check_data_overwrite(new_data_path)
|
||||||
# Save the new location.
|
# Save the new location.
|
||||||
Receiver.send_message(u'set_new_data_path', new_data_path)
|
self.main_window.set_new_data_path(new_data_path)
|
||||||
self.new_data_directory_edit.setText(new_data_path)
|
self.new_data_directory_edit.setText(new_data_path)
|
||||||
self.data_directory_cancel_button.show()
|
self.data_directory_cancel_button.show()
|
||||||
|
|
||||||
@ -594,7 +591,7 @@ class AdvancedTab(SettingsTab):
|
|||||||
return
|
return
|
||||||
self.check_data_overwrite(new_data_path)
|
self.check_data_overwrite(new_data_path)
|
||||||
# Save the new location.
|
# Save the new location.
|
||||||
Receiver.send_message(u'set_new_data_path', new_data_path)
|
self.main_window.set_new_data_path(new_data_path)
|
||||||
self.new_data_directory_edit.setText(os.path.abspath(new_data_path))
|
self.new_data_directory_edit.setText(os.path.abspath(new_data_path))
|
||||||
self.data_directory_cancel_button.show()
|
self.data_directory_cancel_button.show()
|
||||||
else:
|
else:
|
||||||
@ -605,8 +602,7 @@ class AdvancedTab(SettingsTab):
|
|||||||
"""
|
"""
|
||||||
Copy existing data when you change your data directory.
|
Copy existing data when you change your data directory.
|
||||||
"""
|
"""
|
||||||
Receiver.send_message(u'set_copy_data',
|
self.main_window.set_copy_data(self.data_directory_copy_check_box.isChecked())
|
||||||
self.data_directory_copy_check_box.isChecked())
|
|
||||||
if self.data_exists:
|
if self.data_exists:
|
||||||
if self.data_directory_copy_check_box.isChecked():
|
if self.data_directory_copy_check_box.isChecked():
|
||||||
self.new_data_directory_has_files_label.show()
|
self.new_data_directory_has_files_label.show()
|
||||||
@ -645,8 +641,8 @@ class AdvancedTab(SettingsTab):
|
|||||||
"""
|
"""
|
||||||
self.new_data_directory_edit.clear()
|
self.new_data_directory_edit.clear()
|
||||||
self.data_directory_copy_check_box.setChecked(False)
|
self.data_directory_copy_check_box.setChecked(False)
|
||||||
Receiver.send_message(u'set_new_data_path', u'')
|
self.main_window.set_new_data_path(None)
|
||||||
Receiver.send_message(u'set_copy_data', False)
|
self.main_window.set_copy_data(False)
|
||||||
self.data_directory_copy_check_box.hide()
|
self.data_directory_copy_check_box.hide()
|
||||||
self.data_directory_cancel_button.hide()
|
self.data_directory_cancel_button.hide()
|
||||||
self.new_data_directory_has_files_label.hide()
|
self.new_data_directory_has_files_label.hide()
|
||||||
|
@ -41,7 +41,7 @@ from ConfigParser import SafeConfigParser
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import PluginStatus, Receiver, Settings, Registry, build_icon, check_directory_exists, translate
|
from openlp.core.lib import PluginStatus, Settings, Registry, build_icon, check_directory_exists, translate
|
||||||
from openlp.core.utils import AppLocation, get_web_page, get_filesystem_encoding
|
from openlp.core.utils import AppLocation, get_web_page, get_filesystem_encoding
|
||||||
from firsttimewizard import Ui_FirstTimeWizard, FirstTimePage
|
from firsttimewizard import Ui_FirstTimeWizard, FirstTimePage
|
||||||
|
|
||||||
@ -95,7 +95,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard):
|
|||||||
if self.web_access:
|
if self.web_access:
|
||||||
files = self.web_access.read()
|
files = self.web_access.read()
|
||||||
self.config.readfp(io.BytesIO(files))
|
self.config.readfp(io.BytesIO(files))
|
||||||
self.updateScreenListCombo()
|
self.update_screen_list_combo()
|
||||||
self.was_download_cancelled = False
|
self.was_download_cancelled = False
|
||||||
self.downloading = translate('OpenLP.FirstTimeWizard', 'Downloading %s...')
|
self.downloading = translate('OpenLP.FirstTimeWizard', 'Downloading %s...')
|
||||||
QtCore.QObject.connect(self.cancelButton, QtCore.SIGNAL('clicked()'),
|
QtCore.QObject.connect(self.cancelButton, QtCore.SIGNAL('clicked()'),
|
||||||
@ -103,8 +103,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard):
|
|||||||
QtCore.QObject.connect(self.noInternetFinishButton, QtCore.SIGNAL('clicked()'),
|
QtCore.QObject.connect(self.noInternetFinishButton, QtCore.SIGNAL('clicked()'),
|
||||||
self.onNoInternetFinishButtonClicked)
|
self.onNoInternetFinishButtonClicked)
|
||||||
QtCore.QObject.connect(self, QtCore.SIGNAL(u'currentIdChanged(int)'), self.onCurrentIdChanged)
|
QtCore.QObject.connect(self, QtCore.SIGNAL(u'currentIdChanged(int)'), self.onCurrentIdChanged)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'config_screen_changed'),
|
Registry().register_function(u'config_screen_changed', self.update_screen_list_combo)
|
||||||
self.updateScreenListCombo)
|
|
||||||
|
|
||||||
def exec_(self):
|
def exec_(self):
|
||||||
"""
|
"""
|
||||||
@ -227,7 +226,7 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard):
|
|||||||
self._postWizard()
|
self._postWizard()
|
||||||
self.application.set_normal_cursor()
|
self.application.set_normal_cursor()
|
||||||
|
|
||||||
def updateScreenListCombo(self):
|
def update_screen_list_combo(self):
|
||||||
"""
|
"""
|
||||||
The user changed screen resolution or enabled/disabled more screens, so
|
The user changed screen resolution or enabled/disabled more screens, so
|
||||||
we need to update the combo box.
|
we need to update the combo box.
|
||||||
@ -294,8 +293,8 @@ class FirstTimeForm(QtGui.QWizard, Ui_FirstTimeWizard):
|
|||||||
item = self.themesListWidget.item(index)
|
item = self.themesListWidget.item(index)
|
||||||
if item.data(QtCore.Qt.UserRole) == filename:
|
if item.data(QtCore.Qt.UserRole) == filename:
|
||||||
break
|
break
|
||||||
item.setIcon(build_icon(os.path.join(unicode(gettempdir(), get_filesystem_encoding()), u'openlp',
|
item.setIcon(build_icon(os.path.join(unicode(gettempdir(),
|
||||||
screenshot)))
|
get_filesystem_encoding()), u'openlp', screenshot)))
|
||||||
|
|
||||||
def _getFileSize(self, url):
|
def _getFileSize(self, url):
|
||||||
"""
|
"""
|
||||||
|
@ -33,7 +33,7 @@ import logging
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, Settings, SettingsTab, ScreenList, UiStrings, translate
|
from openlp.core.lib import Registry, Settings, SettingsTab, ScreenList, UiStrings, translate
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
@ -199,7 +199,7 @@ class GeneralTab(SettingsTab):
|
|||||||
QtCore.QObject.connect(self.customXValueEdit, QtCore.SIGNAL(u'valueChanged(int)'), self.onDisplayChanged)
|
QtCore.QObject.connect(self.customXValueEdit, QtCore.SIGNAL(u'valueChanged(int)'), self.onDisplayChanged)
|
||||||
QtCore.QObject.connect(self.monitorComboBox, QtCore.SIGNAL(u'currentIndexChanged(int)'), self.onDisplayChanged)
|
QtCore.QObject.connect(self.monitorComboBox, QtCore.SIGNAL(u'currentIndexChanged(int)'), self.onDisplayChanged)
|
||||||
# Reload the tab, as the screen resolution/count may have changed.
|
# Reload the tab, as the screen resolution/count may have changed.
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'config_screen_changed'), self.load)
|
Registry().register_function(u'config_screen_changed', self.load)
|
||||||
# Remove for now
|
# Remove for now
|
||||||
self.usernameLabel.setVisible(False)
|
self.usernameLabel.setVisible(False)
|
||||||
self.usernameEdit.setVisible(False)
|
self.usernameEdit.setVisible(False)
|
||||||
@ -315,7 +315,7 @@ class GeneralTab(SettingsTab):
|
|||||||
Apply settings after settings tab has loaded and most of the
|
Apply settings after settings tab has loaded and most of the
|
||||||
system so must be delayed
|
system so must be delayed
|
||||||
"""
|
"""
|
||||||
Receiver.send_message(u'slidecontroller_live_spin_delay', self.timeoutSpinBox.value())
|
Registry().execute(u'slidecontroller_live_spin_delay', self.timeoutSpinBox.value())
|
||||||
# Do not continue on start up.
|
# Do not continue on start up.
|
||||||
if not postUpdate:
|
if not postUpdate:
|
||||||
return
|
return
|
||||||
@ -331,7 +331,7 @@ class GeneralTab(SettingsTab):
|
|||||||
else:
|
else:
|
||||||
self.screens.reset_current_display()
|
self.screens.reset_current_display()
|
||||||
if self.display_changed:
|
if self.display_changed:
|
||||||
Receiver.send_message(u'config_screen_changed')
|
Registry().execute(u'config_screen_changed')
|
||||||
self.display_changed = False
|
self.display_changed = False
|
||||||
|
|
||||||
def onOverrideRadioButtonPressed(self, checked):
|
def onOverrideRadioButtonPressed(self, checked):
|
||||||
|
@ -42,7 +42,7 @@ import sys
|
|||||||
from PyQt4 import QtCore, QtGui, QtWebKit, QtOpenGL
|
from PyQt4 import QtCore, QtGui, QtWebKit, QtOpenGL
|
||||||
from PyQt4.phonon import Phonon
|
from PyQt4.phonon import Phonon
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, ServiceItem, Settings, ImageSource, Registry, build_html, expand_tags, \
|
from openlp.core.lib import ServiceItem, Settings, ImageSource, Registry, build_html, expand_tags, \
|
||||||
image_to_byte, translate
|
image_to_byte, translate
|
||||||
from openlp.core.lib.theme import BackgroundType
|
from openlp.core.lib.theme import BackgroundType
|
||||||
|
|
||||||
@ -158,10 +158,10 @@ class MainDisplay(Display):
|
|||||||
self.setAttribute(QtCore.Qt.WA_DeleteOnClose)
|
self.setAttribute(QtCore.Qt.WA_DeleteOnClose)
|
||||||
self.setTransparency(False)
|
self.setTransparency(False)
|
||||||
if self.isLive:
|
if self.isLive:
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'live_display_hide'), self.hideDisplay)
|
Registry().register_function(u'live_display_hide', self.hide_display)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'live_display_show'), self.showDisplay)
|
Registry().register_function(u'live_display_show', self.show_display)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'update_display_css'), self.cssChanged)
|
Registry().register_function(u'update_display_css', self.css_changed)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'config_updated'), self.configChanged)
|
Registry().register_function(u'config_updated', self.config_changed)
|
||||||
|
|
||||||
def setTransparency(self, enabled):
|
def setTransparency(self, enabled):
|
||||||
"""
|
"""
|
||||||
@ -174,13 +174,13 @@ class MainDisplay(Display):
|
|||||||
self.setAttribute(QtCore.Qt.WA_TranslucentBackground, enabled)
|
self.setAttribute(QtCore.Qt.WA_TranslucentBackground, enabled)
|
||||||
self.repaint()
|
self.repaint()
|
||||||
|
|
||||||
def cssChanged(self):
|
def css_changed(self):
|
||||||
"""
|
"""
|
||||||
We may need to rebuild the CSS on the live display.
|
We may need to rebuild the CSS on the live display.
|
||||||
"""
|
"""
|
||||||
self.rebuildCSS = True
|
self.rebuildCSS = True
|
||||||
|
|
||||||
def configChanged(self):
|
def config_changed(self):
|
||||||
"""
|
"""
|
||||||
Call the plugins to rebuild the Live display CSS as the screen has
|
Call the plugins to rebuild the Live display CSS as the screen has
|
||||||
not been rebuild on exit of config.
|
not been rebuild on exit of config.
|
||||||
@ -362,7 +362,7 @@ class MainDisplay(Display):
|
|||||||
# if was hidden keep it hidden
|
# if was hidden keep it hidden
|
||||||
if self.isLive:
|
if self.isLive:
|
||||||
if self.hideMode:
|
if self.hideMode:
|
||||||
self.hideDisplay(self.hideMode)
|
self.hide_display(self.hideMode)
|
||||||
else:
|
else:
|
||||||
# Single screen active
|
# Single screen active
|
||||||
if self.screens.display_count == 1:
|
if self.screens.display_count == 1:
|
||||||
@ -387,11 +387,11 @@ class MainDisplay(Display):
|
|||||||
if self.override:
|
if self.override:
|
||||||
# We have an video override so allow it to be stopped.
|
# We have an video override so allow it to be stopped.
|
||||||
if u'video' in self.override:
|
if u'video' in self.override:
|
||||||
Receiver.send_message(u'video_background_replaced')
|
Registry().execute(u'video_background_replaced')
|
||||||
self.override = {}
|
self.override = {}
|
||||||
# We have a different theme.
|
# We have a different theme.
|
||||||
elif self.override[u'theme'] != serviceItem.themedata.background_filename:
|
elif self.override[u'theme'] != serviceItem.themedata.background_filename:
|
||||||
Receiver.send_message(u'live_theme_changed')
|
Registry().execute(u'live_theme_changed')
|
||||||
self.override = {}
|
self.override = {}
|
||||||
else:
|
else:
|
||||||
# replace the background
|
# replace the background
|
||||||
@ -417,9 +417,9 @@ class MainDisplay(Display):
|
|||||||
# if was hidden keep it hidden
|
# if was hidden keep it hidden
|
||||||
if self.hideMode and self.isLive and not serviceItem.is_media():
|
if self.hideMode and self.isLive and not serviceItem.is_media():
|
||||||
if Settings().value(u'general/auto unblank'):
|
if Settings().value(u'general/auto unblank'):
|
||||||
Receiver.send_message(u'slidecontroller_live_unblank')
|
Registry().execute(u'slidecontroller_live_unblank')
|
||||||
else:
|
else:
|
||||||
self.hideDisplay(self.hideMode)
|
self.hide_display(self.hideMode)
|
||||||
self.__hideMouse()
|
self.__hideMouse()
|
||||||
|
|
||||||
def footer(self, text):
|
def footer(self, text):
|
||||||
@ -430,12 +430,12 @@ class MainDisplay(Display):
|
|||||||
js = u'show_footer(\'' + text.replace(u'\\', u'\\\\').replace(u'\'', u'\\\'') + u'\')'
|
js = u'show_footer(\'' + text.replace(u'\\', u'\\\\').replace(u'\'', u'\\\'') + u'\')'
|
||||||
self.frame.evaluateJavaScript(js)
|
self.frame.evaluateJavaScript(js)
|
||||||
|
|
||||||
def hideDisplay(self, mode=HideMode.Screen):
|
def hide_display(self, mode=HideMode.Screen):
|
||||||
"""
|
"""
|
||||||
Hide the display by making all layers transparent
|
Hide the display by making all layers transparent
|
||||||
Store the images so they can be replaced when required
|
Store the images so they can be replaced when required
|
||||||
"""
|
"""
|
||||||
log.debug(u'hideDisplay mode = %d', mode)
|
log.debug(u'hide_display mode = %d', mode)
|
||||||
if self.screens.display_count == 1:
|
if self.screens.display_count == 1:
|
||||||
# Only make visible if setting enabled.
|
# Only make visible if setting enabled.
|
||||||
if not Settings().value(u'general/display on monitor'):
|
if not Settings().value(u'general/display on monitor'):
|
||||||
@ -453,13 +453,13 @@ class MainDisplay(Display):
|
|||||||
self.webView.setVisible(True)
|
self.webView.setVisible(True)
|
||||||
self.hideMode = mode
|
self.hideMode = mode
|
||||||
|
|
||||||
def showDisplay(self):
|
def show_display(self):
|
||||||
"""
|
"""
|
||||||
Show the stored layers so the screen reappears as it was
|
Show the stored layers so the screen reappears as it was
|
||||||
originally.
|
originally.
|
||||||
Make the stored images None to release memory.
|
Make the stored images None to release memory.
|
||||||
"""
|
"""
|
||||||
log.debug(u'showDisplay')
|
log.debug(u'show_display')
|
||||||
if self.screens.display_count == 1:
|
if self.screens.display_count == 1:
|
||||||
# Only make visible if setting enabled.
|
# Only make visible if setting enabled.
|
||||||
if not Settings().value(u'general/display on monitor'):
|
if not Settings().value(u'general/display on monitor'):
|
||||||
@ -470,7 +470,7 @@ class MainDisplay(Display):
|
|||||||
self.hideMode = None
|
self.hideMode = None
|
||||||
# Trigger actions when display is active again.
|
# Trigger actions when display is active again.
|
||||||
if self.isLive:
|
if self.isLive:
|
||||||
Receiver.send_message(u'live_display_active')
|
Registry().execute(u'live_display_active')
|
||||||
|
|
||||||
def __hideMouse(self):
|
def __hideMouse(self):
|
||||||
"""
|
"""
|
||||||
|
@ -41,7 +41,7 @@ from datetime import datetime
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Renderer, OpenLPDockWidget, PluginManager, Receiver, ImageManager, PluginStatus, Registry, \
|
from openlp.core.lib import Renderer, OpenLPDockWidget, PluginManager, ImageManager, PluginStatus, Registry, \
|
||||||
Settings, ScreenList, build_icon, check_directory_exists, translate
|
Settings, ScreenList, build_icon, check_directory_exists, translate
|
||||||
from openlp.core.lib.ui import UiStrings, create_action
|
from openlp.core.lib.ui import UiStrings, create_action
|
||||||
from openlp.core.ui import AboutForm, SettingsForm, ServiceManager, ThemeManager, SlideController, PluginForm, \
|
from openlp.core.ui import AboutForm, SettingsForm, ServiceManager, ThemeManager, SlideController, PluginForm, \
|
||||||
@ -484,6 +484,8 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow):
|
|||||||
self.formattingTagForm = FormattingTagForm(self)
|
self.formattingTagForm = FormattingTagForm(self)
|
||||||
self.shortcutForm = ShortcutListForm(self)
|
self.shortcutForm = ShortcutListForm(self)
|
||||||
self.recentFiles = []
|
self.recentFiles = []
|
||||||
|
self.timer_id = 0
|
||||||
|
self.timer_version_id = 0
|
||||||
# Set up the path with plugins
|
# Set up the path with plugins
|
||||||
plugin_path = AppLocation.get_directory(AppLocation.PluginsDir)
|
plugin_path = AppLocation.get_directory(AppLocation.PluginsDir)
|
||||||
self.plugin_manager = PluginManager(plugin_path)
|
self.plugin_manager = PluginManager(plugin_path)
|
||||||
@ -497,8 +499,8 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow):
|
|||||||
# Once settings are loaded update the menu with the recent files.
|
# Once settings are loaded update the menu with the recent files.
|
||||||
self.updateRecentFilesMenu()
|
self.updateRecentFilesMenu()
|
||||||
self.pluginForm = PluginForm(self)
|
self.pluginForm = PluginForm(self)
|
||||||
self.newDataPath = u''
|
self.new_data_path = None
|
||||||
self.copyData = False
|
self.copy_data = False
|
||||||
# Set up signals and slots
|
# Set up signals and slots
|
||||||
QtCore.QObject.connect(self.importThemeItem, QtCore.SIGNAL(u'triggered()'),
|
QtCore.QObject.connect(self.importThemeItem, QtCore.SIGNAL(u'triggered()'),
|
||||||
self.themeManagerContents.on_import_theme)
|
self.themeManagerContents.on_import_theme)
|
||||||
@ -528,25 +530,13 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow):
|
|||||||
QtCore.QObject.connect(self.modeDefaultItem, QtCore.SIGNAL(u'triggered()'), self.onModeDefaultItemClicked)
|
QtCore.QObject.connect(self.modeDefaultItem, QtCore.SIGNAL(u'triggered()'), self.onModeDefaultItemClicked)
|
||||||
QtCore.QObject.connect(self.modeSetupItem, QtCore.SIGNAL(u'triggered()'), self.onModeSetupItemClicked)
|
QtCore.QObject.connect(self.modeSetupItem, QtCore.SIGNAL(u'triggered()'), self.onModeSetupItemClicked)
|
||||||
QtCore.QObject.connect(self.modeLiveItem, QtCore.SIGNAL(u'triggered()'), self.onModeLiveItemClicked)
|
QtCore.QObject.connect(self.modeLiveItem, QtCore.SIGNAL(u'triggered()'), self.onModeLiveItemClicked)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'theme_update_global'), self.defaultThemeChanged)
|
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'openlp_version_check'), self.versionNotice)
|
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'live_display_blank_check'), self.blankCheck)
|
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'config_screen_changed'), self.screenChanged)
|
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'mainwindow_status_text'),
|
|
||||||
self.showStatusMessage)
|
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'cleanup'), self.clean_up)
|
|
||||||
# Media Manager
|
# Media Manager
|
||||||
QtCore.QObject.connect(self.mediaToolBox, QtCore.SIGNAL(u'currentChanged(int)'), self.onMediaToolBoxChanged)
|
QtCore.QObject.connect(self.mediaToolBox, QtCore.SIGNAL(u'currentChanged(int)'), self.onMediaToolBoxChanged)
|
||||||
self.application.set_busy_cursor()
|
self.application.set_busy_cursor()
|
||||||
# Simple message boxes
|
# Simple message boxes
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'openlp_error_message'), self.onErrorMessage)
|
Registry().register_function(u'theme_update_global', self.default_theme_changed)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'openlp_information_message'),
|
Registry().register_function(u'openlp_version_check', self.version_notice)
|
||||||
self.onInformationMessage)
|
Registry().register_function(u'config_screen_changed', self.screen_changed)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'set_new_data_path'), self.setNewDataPath)
|
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'set_copy_data'), self.setCopyData)
|
|
||||||
# warning cyclic dependency
|
|
||||||
# renderer needs to call ThemeManager and
|
|
||||||
# ThemeManager needs to call Renderer
|
|
||||||
self.renderer = Renderer()
|
self.renderer = Renderer()
|
||||||
# Define the media Dock Manager
|
# Define the media Dock Manager
|
||||||
self.mediaDockManager = MediaDockManager(self.mediaToolBox)
|
self.mediaDockManager = MediaDockManager(self.mediaToolBox)
|
||||||
@ -582,8 +572,6 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow):
|
|||||||
# Once all components are initialised load the Themes
|
# Once all components are initialised load the Themes
|
||||||
log.info(u'Load Themes')
|
log.info(u'Load Themes')
|
||||||
self.themeManagerContents.load_themes(True)
|
self.themeManagerContents.load_themes(True)
|
||||||
# Hide/show the theme combobox on the service manager
|
|
||||||
self.serviceManagerContents.theme_change()
|
|
||||||
# Reset the cursor
|
# Reset the cursor
|
||||||
self.application.set_normal_cursor()
|
self.application.set_normal_cursor()
|
||||||
|
|
||||||
@ -603,16 +591,15 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow):
|
|||||||
if widget:
|
if widget:
|
||||||
widget.onFocus()
|
widget.onFocus()
|
||||||
|
|
||||||
def versionNotice(self, version):
|
def version_notice(self, version):
|
||||||
"""
|
"""
|
||||||
Notifies the user that a newer version of OpenLP is available.
|
Notifies the user that a newer version of OpenLP is available.
|
||||||
Triggered by delay thread.
|
Triggered by delay thread and cannot display popup.
|
||||||
"""
|
"""
|
||||||
|
log.debug(u'version_notice')
|
||||||
version_text = translate('OpenLP.MainWindow', 'Version %s of OpenLP is now available for download (you are '
|
version_text = translate('OpenLP.MainWindow', 'Version %s of OpenLP is now available for download (you are '
|
||||||
'currently running version %s). \n\nYou can download the latest version from http://openlp.org/.')
|
'currently running version %s). \n\nYou can download the latest version from http://openlp.org/.')
|
||||||
QtGui.QMessageBox.question(self,
|
self.version_text = version_text % (version, get_application_version()[u'full'])
|
||||||
translate('OpenLP.MainWindow', 'OpenLP Version Updated'),
|
|
||||||
version_text % (version, get_application_version()[u'full']))
|
|
||||||
|
|
||||||
def show(self):
|
def show(self):
|
||||||
"""
|
"""
|
||||||
@ -632,6 +619,7 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow):
|
|||||||
self.serviceManagerContents.load_file(filename)
|
self.serviceManagerContents.load_file(filename)
|
||||||
elif Settings().value(self.generalSettingsSection + u'/auto open'):
|
elif Settings().value(self.generalSettingsSection + u'/auto open'):
|
||||||
self.serviceManagerContents.load_Last_file()
|
self.serviceManagerContents.load_Last_file()
|
||||||
|
self.timer_version_id = self.startTimer(1000)
|
||||||
view_mode = Settings().value(u'%s/view mode' % self.generalSettingsSection)
|
view_mode = Settings().value(u'%s/view mode' % self.generalSettingsSection)
|
||||||
if view_mode == u'default':
|
if view_mode == u'default':
|
||||||
self.modeDefaultItem.setChecked(True)
|
self.modeDefaultItem.setChecked(True)
|
||||||
@ -701,13 +689,13 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow):
|
|||||||
self.activePlugin.toggleStatus(PluginStatus.Inactive)
|
self.activePlugin.toggleStatus(PluginStatus.Inactive)
|
||||||
self.themeManagerContents.config_updated()
|
self.themeManagerContents.config_updated()
|
||||||
self.themeManagerContents.load_themes(True)
|
self.themeManagerContents.load_themes(True)
|
||||||
Receiver.send_message(u'theme_update_global', self.themeManagerContents.global_theme)
|
Registry().execute(u'theme_update_global', self.themeManagerContents.global_theme)
|
||||||
# Check if any Bibles downloaded. If there are, they will be
|
# Check if any Bibles downloaded. If there are, they will be
|
||||||
# processed.
|
# processed.
|
||||||
Receiver.send_message(u'bibles_load_list', True)
|
Registry().execute(u'bibles_load_list', True)
|
||||||
self.application.set_normal_cursor()
|
self.application.set_normal_cursor()
|
||||||
|
|
||||||
def blankCheck(self):
|
def is_display_blank(self):
|
||||||
"""
|
"""
|
||||||
Check and display message if screen blank on setup.
|
Check and display message if screen blank on setup.
|
||||||
"""
|
"""
|
||||||
@ -718,26 +706,44 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow):
|
|||||||
QtGui.QMessageBox.question(self, translate('OpenLP.MainWindow', 'OpenLP Main Display Blanked'),
|
QtGui.QMessageBox.question(self, translate('OpenLP.MainWindow', 'OpenLP Main Display Blanked'),
|
||||||
translate('OpenLP.MainWindow', 'The Main Display has been blanked out'))
|
translate('OpenLP.MainWindow', 'The Main Display has been blanked out'))
|
||||||
|
|
||||||
def onErrorMessage(self, data):
|
def error_message(self, title, message):
|
||||||
"""
|
"""
|
||||||
Display an error message
|
Display an error message
|
||||||
"""
|
|
||||||
self.application.close_splash_screen()
|
|
||||||
QtGui.QMessageBox.critical(self, data[u'title'], data[u'message'])
|
|
||||||
|
|
||||||
def warning_message(self, message):
|
``title``
|
||||||
|
The title of the warning box.
|
||||||
|
|
||||||
|
``message``
|
||||||
|
The message to be displayed.
|
||||||
|
"""
|
||||||
|
self.application.splash.close()
|
||||||
|
QtGui.QMessageBox.critical(self, title, message)
|
||||||
|
|
||||||
|
def warning_message(self, title, message):
|
||||||
"""
|
"""
|
||||||
Display a warning message
|
Display a warning message
|
||||||
"""
|
|
||||||
self.application.close_splash_screen()
|
|
||||||
QtGui.QMessageBox.warning(self, message[u'title'], message[u'message'])
|
|
||||||
|
|
||||||
def onInformationMessage(self, data):
|
``title``
|
||||||
|
The title of the warning box.
|
||||||
|
|
||||||
|
``message``
|
||||||
|
The message to be displayed.
|
||||||
|
"""
|
||||||
|
self.application.splash.close()
|
||||||
|
QtGui.QMessageBox.warning(self, title, message)
|
||||||
|
|
||||||
|
def information_message(self, title, message):
|
||||||
"""
|
"""
|
||||||
Display an informational message
|
Display an informational message
|
||||||
|
|
||||||
|
``title``
|
||||||
|
The title of the warning box.
|
||||||
|
|
||||||
|
``message``
|
||||||
|
The message to be displayed.
|
||||||
"""
|
"""
|
||||||
self.application.close_splash_screen()
|
self.application.splash.close()
|
||||||
QtGui.QMessageBox.information(self, data[u'title'], data[u'message'])
|
QtGui.QMessageBox.information(self, title, message)
|
||||||
|
|
||||||
def onHelpWebSiteClicked(self):
|
def onHelpWebSiteClicked(self):
|
||||||
"""
|
"""
|
||||||
@ -1003,12 +1009,12 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow):
|
|||||||
self.setPreviewPanelVisibility(preview)
|
self.setPreviewPanelVisibility(preview)
|
||||||
self.setLivePanelVisibility(live)
|
self.setLivePanelVisibility(live)
|
||||||
|
|
||||||
def screenChanged(self):
|
def screen_changed(self):
|
||||||
"""
|
"""
|
||||||
The screen has changed so we have to update components such as the
|
The screen has changed so we have to update components such as the
|
||||||
renderer.
|
renderer.
|
||||||
"""
|
"""
|
||||||
log.debug(u'screenChanged')
|
log.debug(u'screen_changed')
|
||||||
self.application.set_busy_cursor()
|
self.application.set_busy_cursor()
|
||||||
self.imageManager.update_display()
|
self.imageManager.update_display()
|
||||||
self.renderer.update_display()
|
self.renderer.update_display()
|
||||||
@ -1081,14 +1087,12 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow):
|
|||||||
# Save settings
|
# Save settings
|
||||||
self.saveSettings()
|
self.saveSettings()
|
||||||
# Check if we need to change the data directory
|
# Check if we need to change the data directory
|
||||||
if self.newDataPath:
|
if self.new_data_path:
|
||||||
self.changeDataDirectory()
|
self.changeDataDirectory()
|
||||||
# Close down the display
|
# Close down the display
|
||||||
if self.liveController.display:
|
if self.liveController.display:
|
||||||
self.liveController.display.close()
|
self.liveController.display.close()
|
||||||
self.liveController.display = None
|
self.liveController.display = None
|
||||||
# Allow the main process to exit
|
|
||||||
self.application = None
|
|
||||||
|
|
||||||
def serviceChanged(self, reset=False, serviceName=None):
|
def serviceChanged(self, reset=False, serviceName=None):
|
||||||
"""
|
"""
|
||||||
@ -1129,13 +1133,13 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow):
|
|||||||
title = u'%s - %s' % (self.mainTitle, fileName)
|
title = u'%s - %s' % (self.mainTitle, fileName)
|
||||||
self.setWindowTitle(title)
|
self.setWindowTitle(title)
|
||||||
|
|
||||||
def showStatusMessage(self, message):
|
def show_status_message(self, message):
|
||||||
"""
|
"""
|
||||||
Show a message in the status bar
|
Show a message in the status bar
|
||||||
"""
|
"""
|
||||||
self.statusBar.showMessage(message)
|
self.statusBar.showMessage(message)
|
||||||
|
|
||||||
def defaultThemeChanged(self, theme):
|
def default_theme_changed(self, theme):
|
||||||
"""
|
"""
|
||||||
Update the default theme indicator in the status bar
|
Update the default theme indicator in the status bar
|
||||||
"""
|
"""
|
||||||
@ -1338,34 +1342,45 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow):
|
|||||||
self.timer_id = 0
|
self.timer_id = 0
|
||||||
self.loadProgressBar.hide()
|
self.loadProgressBar.hide()
|
||||||
self.application.process_events()
|
self.application.process_events()
|
||||||
|
if event.timerId() == self.timer_version_id:
|
||||||
|
self.timer_version_id = 0
|
||||||
|
# Has the thread passed some data to be displayed so display it and stop all waiting
|
||||||
|
if hasattr(self, u'version_text'):
|
||||||
|
QtGui.QMessageBox.question(self, translate('OpenLP.MainWindow', 'OpenLP Version Updated'),
|
||||||
|
self.version_text)
|
||||||
|
else:
|
||||||
|
# the thread has not confirmed it is running or it has not yet sent any data so lets keep waiting
|
||||||
|
if not hasattr(self,u'version_update_running') or self.version_update_running:
|
||||||
|
self.timer_version_id = self.startTimer(1000)
|
||||||
|
self.application.process_events()
|
||||||
|
|
||||||
def setNewDataPath(self, new_data_path):
|
def set_new_data_path(self, new_data_path):
|
||||||
"""
|
"""
|
||||||
Set the new data path
|
Set the new data path
|
||||||
"""
|
"""
|
||||||
self.newDataPath = new_data_path
|
self.new_data_path = new_data_path
|
||||||
|
|
||||||
def setCopyData(self, copy_data):
|
def set_copy_data(self, copy_data):
|
||||||
"""
|
"""
|
||||||
Set the flag to copy the data
|
Set the flag to copy the data
|
||||||
"""
|
"""
|
||||||
self.copyData = copy_data
|
self.copy_data = copy_data
|
||||||
|
|
||||||
def changeDataDirectory(self):
|
def changeDataDirectory(self):
|
||||||
"""
|
"""
|
||||||
Change the data directory.
|
Change the data directory.
|
||||||
"""
|
"""
|
||||||
log.info(u'Changing data path to %s' % self.newDataPath)
|
log.info(u'Changing data path to %s' % self.new_data_path)
|
||||||
old_data_path = unicode(AppLocation.get_data_path())
|
old_data_path = unicode(AppLocation.get_data_path())
|
||||||
# Copy OpenLP data to new location if requested.
|
# Copy OpenLP data to new location if requested.
|
||||||
self.application.set_busy_cursor()
|
self.application.set_busy_cursor()
|
||||||
if self.copyData:
|
if self.copy_data:
|
||||||
log.info(u'Copying data to new path')
|
log.info(u'Copying data to new path')
|
||||||
try:
|
try:
|
||||||
self.showStatusMessage(
|
self.showStatusMessage(
|
||||||
translate('OpenLP.MainWindow', 'Copying OpenLP data to new data directory location - %s '
|
translate('OpenLP.MainWindow', 'Copying OpenLP data to new data directory location - %s '
|
||||||
'- Please wait for copy to finish').replace('%s', self.newDataPath))
|
'- Please wait for copy to finish').replace('%s', self.new_data_path))
|
||||||
dir_util.copy_tree(old_data_path, self.newDataPath)
|
dir_util.copy_tree(old_data_path, self.new_data_path)
|
||||||
log.info(u'Copy sucessful')
|
log.info(u'Copy sucessful')
|
||||||
except (IOError, os.error, DistutilsFileError), why:
|
except (IOError, os.error, DistutilsFileError), why:
|
||||||
self.application.set_normal_cursor()
|
self.application.set_normal_cursor()
|
||||||
@ -1379,9 +1394,9 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow):
|
|||||||
log.info(u'No data copy requested')
|
log.info(u'No data copy requested')
|
||||||
# Change the location of data directory in config file.
|
# Change the location of data directory in config file.
|
||||||
settings = QtCore.QSettings()
|
settings = QtCore.QSettings()
|
||||||
settings.setValue(u'advanced/data path', self.newDataPath)
|
settings.setValue(u'advanced/data path', self.new_data_path)
|
||||||
# Check if the new data path is our default.
|
# Check if the new data path is our default.
|
||||||
if self.newDataPath == AppLocation.get_directory(AppLocation.DataDir):
|
if self.new_data_path == AppLocation.get_directory(AppLocation.DataDir):
|
||||||
settings.remove(u'advanced/data path')
|
settings.remove(u'advanced/data path')
|
||||||
self.application.set_normal_cursor()
|
self.application.set_normal_cursor()
|
||||||
|
|
||||||
|
@ -35,7 +35,7 @@ import os
|
|||||||
import datetime
|
import datetime
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import OpenLPToolbar, Receiver, Settings, Registry, UiStrings, translate
|
from openlp.core.lib import OpenLPToolbar, Settings, Registry, UiStrings, translate
|
||||||
from openlp.core.lib.ui import critical_error_message_box
|
from openlp.core.lib.ui import critical_error_message_box
|
||||||
from openlp.core.ui.media import MediaState, MediaInfo, MediaType, get_media_players, set_media_players
|
from openlp.core.ui.media import MediaState, MediaInfo, MediaType, get_media_players, set_media_players
|
||||||
from openlp.core.ui.media.mediaplayer import MediaPlayer
|
from openlp.core.ui.media.mediaplayer import MediaPlayer
|
||||||
@ -107,21 +107,19 @@ class MediaController(object):
|
|||||||
self.timer.setInterval(200)
|
self.timer.setInterval(200)
|
||||||
# Signals
|
# Signals
|
||||||
self.timer.timeout.connect(self.media_state)
|
self.timer.timeout.connect(self.media_state)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'playbackPlay'), self.media_play_msg)
|
Registry().register_function(u'playbackPlay', self.media_play_msg)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'playbackPause'), self.media_pause_msg)
|
Registry().register_function(u'playbackPause', self.media_pause_msg)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'playbackStop'), self.media_stop_msg)
|
Registry().register_function(u'playbackStop', self.media_stop_msg)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'seekSlider'), self.media_seek_msg)
|
Registry().register_function(u'seekSlider', self.media_seek_msg)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'volumeSlider'), self.media_volume_msg)
|
Registry().register_function(u'volumeSlider', self.media_volume_msg)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'media_hide'), self.media_hide)
|
Registry().register_function(u'media_hide', self.media_hide)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'media_blank'), self.media_blank)
|
Registry().register_function(u'media_blank', self.media_blank)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'media_unblank'), self.media_unblank)
|
Registry().register_function(u'media_unblank', self.media_unblank)
|
||||||
# Signals for background video
|
# Signals for background video
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'songs_hide'), self.media_hide)
|
Registry().register_function(u'songs_hide', self.media_hide)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'songs_unblank'), self.media_unblank)
|
Registry().register_function(u'songs_unblank', self.media_unblank)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'mediaitem_media_rebuild'),
|
Registry().register_function(u'mediaitem_media_rebuild', self._set_active_players)
|
||||||
self._set_active_players)
|
Registry().register_function(u'mediaitem_suffixes', self._generate_extensions_lists)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'mediaitem_suffixes'),
|
|
||||||
self._generate_extensions_lists)
|
|
||||||
|
|
||||||
def _set_active_players(self):
|
def _set_active_players(self):
|
||||||
"""
|
"""
|
||||||
@ -694,7 +692,7 @@ class MediaController(object):
|
|||||||
hide_mode = msg[2]
|
hide_mode = msg[2]
|
||||||
if not isLive:
|
if not isLive:
|
||||||
return
|
return
|
||||||
Receiver.send_message(u'live_display_hide', hide_mode)
|
Registry().execute(u'live_display_hide', hide_mode)
|
||||||
controller = self.mainWindow.liveController
|
controller = self.mainWindow.liveController
|
||||||
display = self._define_display(controller)
|
display = self._define_display(controller)
|
||||||
if self.currentMediaPlayer[controller.controllerType].state == MediaState.Playing:
|
if self.currentMediaPlayer[controller.controllerType].state == MediaState.Playing:
|
||||||
@ -709,7 +707,7 @@ class MediaController(object):
|
|||||||
First element is not relevant in this context
|
First element is not relevant in this context
|
||||||
Second element is the boolean for Live indication
|
Second element is the boolean for Live indication
|
||||||
"""
|
"""
|
||||||
Receiver.send_message(u'live_display_show')
|
Registry().execute(u'live_display_show')
|
||||||
isLive = msg[1]
|
isLive = msg[1]
|
||||||
if not isLive:
|
if not isLive:
|
||||||
return
|
return
|
||||||
|
@ -31,7 +31,7 @@ The :mod:`~openlp.core.ui.media.playertab` module holds the configuration tab fo
|
|||||||
"""
|
"""
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import SettingsTab, Receiver, Settings, UiStrings, translate
|
from openlp.core.lib import Registry, SettingsTab, Settings, UiStrings, translate
|
||||||
from openlp.core.lib.ui import create_button
|
from openlp.core.lib.ui import create_button
|
||||||
from openlp.core.ui.media import get_media_players, set_media_players
|
from openlp.core.ui.media import get_media_players, set_media_players
|
||||||
|
|
||||||
@ -229,8 +229,8 @@ class PlayerTab(SettingsTab):
|
|||||||
player_string_changed = True
|
player_string_changed = True
|
||||||
if player_string_changed:
|
if player_string_changed:
|
||||||
self.service_manager.reset_supported_suffixes()
|
self.service_manager.reset_supported_suffixes()
|
||||||
Receiver.send_message(u'mediaitem_media_rebuild')
|
Registry().execute(u'mediaitem_media_rebuild')
|
||||||
Receiver.send_message(u'config_screen_changed')
|
Registry().execute(u'config_screen_changed')
|
||||||
|
|
||||||
def postSetUp(self, postUpdate=False):
|
def postSetUp(self, postUpdate=False):
|
||||||
"""
|
"""
|
||||||
|
@ -36,7 +36,7 @@ import os
|
|||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
from lxml import html
|
from lxml import html
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, Settings, UiStrings, Registry, translate, get_text_file_string
|
from openlp.core.lib import Settings, UiStrings, Registry, translate, get_text_file_string
|
||||||
from openlp.core.ui.printservicedialog import Ui_PrintServiceDialog, ZoomSize
|
from openlp.core.ui.printservicedialog import Ui_PrintServiceDialog, ZoomSize
|
||||||
from openlp.core.utils import AppLocation
|
from openlp.core.utils import AppLocation
|
||||||
|
|
||||||
@ -408,7 +408,7 @@ class PrintServiceForm(QtGui.QDialog, Ui_PrintServiceDialog):
|
|||||||
return
|
return
|
||||||
for item in self.service_manager.serviceItems:
|
for item in self.service_manager.serviceItems:
|
||||||
# Trigger Audit requests
|
# Trigger Audit requests
|
||||||
Receiver.send_message(u'print_service_started', [item[u'service_item']])
|
Registry().register_function(u'print_service_started', [item[u'service_item']])
|
||||||
|
|
||||||
def _get_service_manager(self):
|
def _get_service_manager(self):
|
||||||
"""
|
"""
|
||||||
|
@ -42,7 +42,7 @@ log = logging.getLogger(__name__)
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import OpenLPToolbar, ServiceItem, Receiver, ItemCapabilities, Settings, PluginStatus, Registry, \
|
from openlp.core.lib import OpenLPToolbar, ServiceItem, ItemCapabilities, Settings, PluginStatus, Registry, \
|
||||||
UiStrings, build_icon, translate, str_to_bool, check_directory_exists
|
UiStrings, build_icon, translate, str_to_bool, check_directory_exists
|
||||||
from openlp.core.lib.theme import ThemeLevel
|
from openlp.core.lib.theme import ThemeLevel
|
||||||
from openlp.core.lib.ui import critical_error_message_box, create_widget_action, find_and_set_in_combo_box
|
from openlp.core.lib.ui import critical_error_message_box, create_widget_action, find_and_set_in_combo_box
|
||||||
@ -210,11 +210,10 @@ class ServiceManagerDialog(object):
|
|||||||
self.collapsed)
|
self.collapsed)
|
||||||
QtCore.QObject.connect(self.service_manager_list, QtCore.SIGNAL(u'itemExpanded(QTreeWidgetItem*)'),
|
QtCore.QObject.connect(self.service_manager_list, QtCore.SIGNAL(u'itemExpanded(QTreeWidgetItem*)'),
|
||||||
self.expanded)
|
self.expanded)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'theme_update_list'), self.update_theme_list)
|
Registry().register_function(u'theme_update_list', self.update_theme_list)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'config_updated'), self.config_updated)
|
Registry().register_function(u'config_updated', self.config_updated)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'config_screen_changed'),
|
Registry().register_function(u'config_screen_changed', self.regenerate_service_Items)
|
||||||
self.regenerate_service_Items)
|
Registry().register_function(u'theme_update_global', self.theme_change)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'theme_update_global'), self.theme_change)
|
|
||||||
# Last little bits of setting up
|
# Last little bits of setting up
|
||||||
self.service_theme = Settings().value(self.main_window.serviceManagerSettingsSection + u'/service theme')
|
self.service_theme = Settings().value(self.main_window.serviceManagerSettingsSection + u'/service theme')
|
||||||
self.servicePath = AppLocation.get_section_data_path(u'servicemanager')
|
self.servicePath = AppLocation.get_section_data_path(u'servicemanager')
|
||||||
@ -555,10 +554,9 @@ class ServiceManager(QtGui.QWidget, ServiceManagerDialog):
|
|||||||
zip_file.write(audio_from, audio_to.encode(u'utf-8'))
|
zip_file.write(audio_from, audio_to.encode(u'utf-8'))
|
||||||
except IOError:
|
except IOError:
|
||||||
log.exception(u'Failed to save service to disk: %s', temp_file_name)
|
log.exception(u'Failed to save service to disk: %s', temp_file_name)
|
||||||
Receiver.send_message(u'openlp_error_message', {
|
self.main_window.error_message(translate(u'OpenLP.ServiceManager', u'Error Saving File'),
|
||||||
u'title': translate(u'OpenLP.ServiceManager', u'Error Saving File'),
|
translate(u'OpenLP.ServiceManager', u'There was an error saving your file.')
|
||||||
u'message': translate(u'OpenLP.ServiceManager', u'There was an error saving your file.')
|
)
|
||||||
})
|
|
||||||
success = False
|
success = False
|
||||||
finally:
|
finally:
|
||||||
if zip_file:
|
if zip_file:
|
||||||
@ -613,10 +611,9 @@ class ServiceManager(QtGui.QWidget, ServiceManagerDialog):
|
|||||||
zip_file.writestr(service_file_name.encode(u'utf-8'), service_content)
|
zip_file.writestr(service_file_name.encode(u'utf-8'), service_content)
|
||||||
except IOError:
|
except IOError:
|
||||||
log.exception(u'Failed to save service to disk: %s', temp_file_name)
|
log.exception(u'Failed to save service to disk: %s', temp_file_name)
|
||||||
Receiver.send_message(u'openlp_error_message', {
|
self.main_window.error_message(translate(u'OpenLP.ServiceManager', u'Error Saving File'),
|
||||||
u'title': translate(u'OpenLP.ServiceManager', u'Error Saving File'),
|
translate(u'OpenLP.ServiceManager', u'There was an error saving your file.')
|
||||||
u'message': translate(u'OpenLP.ServiceManager', u'There was an error saving your file.')
|
)
|
||||||
})
|
|
||||||
success = False
|
success = False
|
||||||
finally:
|
finally:
|
||||||
if zip_file:
|
if zip_file:
|
||||||
@ -736,7 +733,7 @@ class ServiceManager(QtGui.QWidget, ServiceManagerDialog):
|
|||||||
service_item.validate_item(self.suffixes)
|
service_item.validate_item(self.suffixes)
|
||||||
self.load_item_unique_identifier = 0
|
self.load_item_unique_identifier = 0
|
||||||
if service_item.is_capable(ItemCapabilities.OnLoadUpdate):
|
if service_item.is_capable(ItemCapabilities.OnLoadUpdate):
|
||||||
Receiver.send_message(u'%s_service_load' % service_item.name.lower(), service_item)
|
Registry().execute(u'%s_service_load' % service_item.name.lower(), service_item)
|
||||||
# if the item has been processed
|
# if the item has been processed
|
||||||
if service_item.unique_identifier == self.load_item_unique_identifier:
|
if service_item.unique_identifier == self.load_item_unique_identifier:
|
||||||
service_item.edit_id = int(self.load_item_edit_id)
|
service_item.edit_id = int(self.load_item_edit_id)
|
||||||
@ -1237,13 +1234,13 @@ class ServiceManager(QtGui.QWidget, ServiceManagerDialog):
|
|||||||
"""
|
"""
|
||||||
Set the theme for the current service.
|
Set the theme for the current service.
|
||||||
"""
|
"""
|
||||||
log.debug(u'ontheme_combo_box_selected')
|
log.debug(u'on_theme_combo_box_selected')
|
||||||
self.service_theme = self.theme_combo_box.currentText()
|
self.service_theme = self.theme_combo_box.currentText()
|
||||||
self.renderer.set_service_theme(self.service_theme)
|
self.renderer.set_service_theme(self.service_theme)
|
||||||
Settings().setValue(self.main_window.serviceManagerSettingsSection + u'/service theme', self.service_theme)
|
Settings().setValue(self.main_window.serviceManagerSettingsSection + u'/service theme', self.service_theme)
|
||||||
self.regenerate_service_Items(True)
|
self.regenerate_service_Items(True)
|
||||||
|
|
||||||
def theme_change(self):
|
def theme_change(self, global_theme):
|
||||||
"""
|
"""
|
||||||
The theme may have changed in the settings dialog so make
|
The theme may have changed in the settings dialog so make
|
||||||
sure the theme combo box is in the correct state.
|
sure the theme combo box is in the correct state.
|
||||||
@ -1439,7 +1436,7 @@ class ServiceManager(QtGui.QWidget, ServiceManagerDialog):
|
|||||||
Saves the current text item as a custom slide
|
Saves the current text item as a custom slide
|
||||||
"""
|
"""
|
||||||
item = self.find_service_item()[0]
|
item = self.find_service_item()[0]
|
||||||
Receiver.send_message(u'custom_create_from_service', self.service_items[item][u'service_item'])
|
Registry().execute(u'custom_create_from_service', self.service_items[item][u'service_item'])
|
||||||
|
|
||||||
def find_service_item(self):
|
def find_service_item(self):
|
||||||
"""
|
"""
|
||||||
@ -1526,7 +1523,7 @@ class ServiceManager(QtGui.QWidget, ServiceManagerDialog):
|
|||||||
replace = True
|
replace = True
|
||||||
else:
|
else:
|
||||||
self.drop_position = self._get_parent_item_data(item)
|
self.drop_position = self._get_parent_item_data(item)
|
||||||
Receiver.send_message(u'%s_add_service_item' % plugin, replace)
|
Registry().execute(u'%s_add_service_item' % plugin, replace)
|
||||||
|
|
||||||
def update_theme_list(self, theme_list):
|
def update_theme_list(self, theme_list):
|
||||||
"""
|
"""
|
||||||
|
@ -33,7 +33,7 @@ import logging
|
|||||||
|
|
||||||
from PyQt4 import QtGui
|
from PyQt4 import QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, PluginStatus, Registry, build_icon
|
from openlp.core.lib import PluginStatus, Registry, build_icon
|
||||||
from openlp.core.ui import AdvancedTab, GeneralTab, ThemesTab
|
from openlp.core.ui import AdvancedTab, GeneralTab, ThemesTab
|
||||||
from openlp.core.ui.media import PlayerTab
|
from openlp.core.ui.media import PlayerTab
|
||||||
from settingsdialog import Ui_SettingsDialog
|
from settingsdialog import Ui_SettingsDialog
|
||||||
@ -107,7 +107,7 @@ class SettingsForm(QtGui.QDialog, Ui_SettingsDialog):
|
|||||||
for tabIndex in range(self.stackedLayout.count()):
|
for tabIndex in range(self.stackedLayout.count()):
|
||||||
self.stackedLayout.widget(tabIndex).save()
|
self.stackedLayout.widget(tabIndex).save()
|
||||||
# Must go after all settings are save
|
# Must go after all settings are save
|
||||||
Receiver.send_message(u'config_updated')
|
Registry().execute(u'config_updated')
|
||||||
return QtGui.QDialog.accept(self)
|
return QtGui.QDialog.accept(self)
|
||||||
|
|
||||||
def reject(self):
|
def reject(self):
|
||||||
|
@ -438,12 +438,11 @@ class ShortcutListForm(QtGui.QDialog, Ui_ShortcutListDialog):
|
|||||||
if changing_action.shortcutContext() in [QtCore.Qt.WindowShortcut, QtCore.Qt.ApplicationShortcut]:
|
if changing_action.shortcutContext() in [QtCore.Qt.WindowShortcut, QtCore.Qt.ApplicationShortcut]:
|
||||||
is_valid = False
|
is_valid = False
|
||||||
if not is_valid:
|
if not is_valid:
|
||||||
self.main_window.warning_message( {
|
self.main_window.warning_message( translate('OpenLP.ShortcutListDialog', 'Duplicate Shortcut'),
|
||||||
u'title': translate('OpenLP.ShortcutListDialog', 'Duplicate Shortcut'),
|
translate('OpenLP.ShortcutListDialog',
|
||||||
u'message': translate('OpenLP.ShortcutListDialog',
|
'The shortcut "%s" is already assigned to another action, please use a different shortcut.') %
|
||||||
'The shortcut "%s" is already assigned to another action, '
|
key_sequence.toString()
|
||||||
'please use a different shortcut.') % key_sequence.toString()
|
)
|
||||||
})
|
|
||||||
return is_valid
|
return is_valid
|
||||||
|
|
||||||
def _actionShortcuts(self, action):
|
def _actionShortcuts(self, action):
|
||||||
|
@ -27,7 +27,7 @@
|
|||||||
# Temple Place, Suite 330, Boston, MA 02111-1307 USA #
|
# Temple Place, Suite 330, Boston, MA 02111-1307 USA #
|
||||||
###############################################################################
|
###############################################################################
|
||||||
"""
|
"""
|
||||||
The :mod:`slidecontroller` module contains argubly the most important part of OpenLP - the slide controller
|
The :mod:`slidecontroller` module contains the most important part of OpenLP - the slide controller
|
||||||
"""
|
"""
|
||||||
import os
|
import os
|
||||||
import logging
|
import logging
|
||||||
@ -36,7 +36,7 @@ from collections import deque
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import OpenLPToolbar, Receiver, ItemCapabilities, ServiceItem, ImageSource, SlideLimits, \
|
from openlp.core.lib import OpenLPToolbar, ItemCapabilities, ServiceItem, ImageSource, SlideLimits, \
|
||||||
ServiceItemAction, Settings, Registry, UiStrings, ScreenList, build_icon, build_html, translate
|
ServiceItemAction, Settings, Registry, UiStrings, ScreenList, build_icon, build_html, translate
|
||||||
from openlp.core.ui import HideMode, MainDisplay, Display, DisplayControllerType
|
from openlp.core.ui import HideMode, MainDisplay, Display, DisplayControllerType
|
||||||
from openlp.core.lib.ui import create_action
|
from openlp.core.lib.ui import create_action
|
||||||
@ -66,7 +66,7 @@ class DisplayController(QtGui.QWidget):
|
|||||||
"""
|
"""
|
||||||
sender = self.sender().objectName() if self.sender().objectName() else self.sender().text()
|
sender = self.sender().objectName() if self.sender().objectName() else self.sender().text()
|
||||||
controller = self
|
controller = self
|
||||||
Receiver.send_message('%s' % sender, [controller, args])
|
Registry().execute('%s' % sender, [controller, args])
|
||||||
|
|
||||||
|
|
||||||
class SlideController(DisplayController):
|
class SlideController(DisplayController):
|
||||||
@ -107,7 +107,7 @@ class SlideController(DisplayController):
|
|||||||
self.selectedRow = 0
|
self.selectedRow = 0
|
||||||
self.serviceItem = None
|
self.serviceItem = None
|
||||||
self.slide_limits = None
|
self.slide_limits = None
|
||||||
self.updateSlideLimits()
|
self.update_slide_limits()
|
||||||
self.panel = QtGui.QWidget(parent.controlSplitter)
|
self.panel = QtGui.QWidget(parent.controlSplitter)
|
||||||
self.slideList = {}
|
self.slideList = {}
|
||||||
# Layout for holding panel
|
# Layout for holding panel
|
||||||
@ -169,13 +169,13 @@ class SlideController(DisplayController):
|
|||||||
text=translate('OpenLP.SlideController', 'Previous Slide'), icon=u':/slides/slide_previous.png',
|
text=translate('OpenLP.SlideController', 'Previous Slide'), icon=u':/slides/slide_previous.png',
|
||||||
tooltip=translate('OpenLP.SlideController', 'Move to previous.'),
|
tooltip=translate('OpenLP.SlideController', 'Move to previous.'),
|
||||||
shortcuts=[QtCore.Qt.Key_Up, QtCore.Qt.Key_PageUp], context=QtCore.Qt.WidgetWithChildrenShortcut,
|
shortcuts=[QtCore.Qt.Key_Up, QtCore.Qt.Key_PageUp], context=QtCore.Qt.WidgetWithChildrenShortcut,
|
||||||
category=self.category, triggers=self.onSlideSelectedPrevious)
|
category=self.category, triggers=self.on_slide_selected_previous)
|
||||||
self.toolbar.addAction(self.previousItem)
|
self.toolbar.addAction(self.previousItem)
|
||||||
self.nextItem = create_action(self, u'nextItem_' + self.typePrefix,
|
self.nextItem = create_action(self, u'nextItem_' + self.typePrefix,
|
||||||
text=translate('OpenLP.SlideController', 'Next Slide'), icon=u':/slides/slide_next.png',
|
text=translate('OpenLP.SlideController', 'Next Slide'), icon=u':/slides/slide_next.png',
|
||||||
tooltip=translate('OpenLP.SlideController', 'Move to next.'),
|
tooltip=translate('OpenLP.SlideController', 'Move to next.'),
|
||||||
shortcuts=[QtCore.Qt.Key_Down, QtCore.Qt.Key_PageDown], context=QtCore.Qt.WidgetWithChildrenShortcut,
|
shortcuts=[QtCore.Qt.Key_Down, QtCore.Qt.Key_PageDown], context=QtCore.Qt.WidgetWithChildrenShortcut,
|
||||||
category=self.category, triggers=self.onSlideSelectedNextAction)
|
category=self.category, triggers=self.on_slide_selected_next_action)
|
||||||
self.toolbar.addAction(self.nextItem)
|
self.toolbar.addAction(self.nextItem)
|
||||||
self.toolbar.addSeparator()
|
self.toolbar.addSeparator()
|
||||||
self.controllerType = DisplayControllerType.Preview
|
self.controllerType = DisplayControllerType.Preview
|
||||||
@ -362,10 +362,8 @@ class SlideController(DisplayController):
|
|||||||
# Signals
|
# Signals
|
||||||
QtCore.QObject.connect(self.previewListWidget, QtCore.SIGNAL(u'clicked(QModelIndex)'), self.onSlideSelected)
|
QtCore.QObject.connect(self.previewListWidget, QtCore.SIGNAL(u'clicked(QModelIndex)'), self.onSlideSelected)
|
||||||
if self.isLive:
|
if self.isLive:
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
Registry().register_function(u'slidecontroller_live_spin_delay', self.receive_spin_delay)
|
||||||
QtCore.SIGNAL(u'slidecontroller_live_spin_delay'), self.receiveSpinDelay)
|
Registry().register_function(u'slidecontroller_toggle_display', self.toggle_display)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
|
||||||
QtCore.SIGNAL(u'slidecontroller_toggle_display'), self.toggleDisplay)
|
|
||||||
self.toolbar.setWidgetVisible(self.loopList, False)
|
self.toolbar.setWidgetVisible(self.loopList, False)
|
||||||
self.toolbar.setWidgetVisible(self.wideMenu, False)
|
self.toolbar.setWidgetVisible(self.wideMenu, False)
|
||||||
else:
|
else:
|
||||||
@ -377,22 +375,14 @@ class SlideController(DisplayController):
|
|||||||
self.__addActionsToWidget(self.previewListWidget)
|
self.__addActionsToWidget(self.previewListWidget)
|
||||||
else:
|
else:
|
||||||
self.previewListWidget.addActions([self.nextItem, self.previousItem])
|
self.previewListWidget.addActions([self.nextItem, self.previousItem])
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
Registry().register_function(u'slidecontroller_%s_stop_loop' % self.typePrefix, self.on_stop_loop)
|
||||||
QtCore.SIGNAL(u'slidecontroller_%s_stop_loop' % self.typePrefix), self.onStopLoop)
|
Registry().register_function(u'slidecontroller_%s_next' % self.typePrefix, self.on_slide_selected_next)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
Registry().register_function(u'slidecontroller_%s_previous' % self.typePrefix, self.on_slide_selected_previous)
|
||||||
QtCore.SIGNAL(u'slidecontroller_%s_next' % self.typePrefix), self.onSlideSelectedNext)
|
Registry().register_function(u'slidecontroller_%s_change' % self.typePrefix, self.on_slide_change)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
Registry().register_function(u'slidecontroller_%s_set' % self.typePrefix, self.on_slide_selected_index)
|
||||||
QtCore.SIGNAL(u'slidecontroller_%s_previous' % self.typePrefix), self.onSlideSelectedPrevious)
|
Registry().register_function(u'slidecontroller_%s_blank' % self.typePrefix, self.on_slide_blank)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
Registry().register_function(u'slidecontroller_%s_unblank' % self.typePrefix, self.on_slide_unblank)
|
||||||
QtCore.SIGNAL(u'slidecontroller_%s_change' % self.typePrefix), self.onSlideChange)
|
Registry().register_function(u'slidecontroller_update_slide_limits', self.update_slide_limits)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
|
||||||
QtCore.SIGNAL(u'slidecontroller_%s_set' % self.typePrefix), self.onSlideSelectedIndex)
|
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
|
||||||
QtCore.SIGNAL(u'slidecontroller_%s_blank' % self.typePrefix), self.onSlideBlank)
|
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
|
||||||
QtCore.SIGNAL(u'slidecontroller_%s_unblank' % self.typePrefix), self.onSlideUnblank)
|
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
|
||||||
QtCore.SIGNAL(u'slidecontroller_update_slide_limits'), self.updateSlideLimits)
|
|
||||||
|
|
||||||
def _slideShortcutActivated(self):
|
def _slideShortcutActivated(self):
|
||||||
"""
|
"""
|
||||||
@ -479,7 +469,7 @@ class SlideController(DisplayController):
|
|||||||
self.display.setVisible(False)
|
self.display.setVisible(False)
|
||||||
self.media_controller.media_stop(self)
|
self.media_controller.media_stop(self)
|
||||||
|
|
||||||
def toggleDisplay(self, action):
|
def toggle_display(self, action):
|
||||||
"""
|
"""
|
||||||
Toggle the display settings triggered from remote messages.
|
Toggle the display settings triggered from remote messages.
|
||||||
"""
|
"""
|
||||||
@ -618,13 +608,13 @@ class SlideController(DisplayController):
|
|||||||
self.__updatePreviewSelection(slide_no)
|
self.__updatePreviewSelection(slide_no)
|
||||||
self.slideSelected()
|
self.slideSelected()
|
||||||
|
|
||||||
def receiveSpinDelay(self, value):
|
def receive_spin_delay(self, value):
|
||||||
"""
|
"""
|
||||||
Adjusts the value of the ``delaySpinBox`` to the given one.
|
Adjusts the value of the ``delaySpinBox`` to the given one.
|
||||||
"""
|
"""
|
||||||
self.delaySpinBox.setValue(int(value))
|
self.delaySpinBox.setValue(int(value))
|
||||||
|
|
||||||
def updateSlideLimits(self):
|
def update_slide_limits(self):
|
||||||
"""
|
"""
|
||||||
Updates the Slide Limits variable from the settings.
|
Updates the Slide Limits variable from the settings.
|
||||||
"""
|
"""
|
||||||
@ -750,14 +740,13 @@ class SlideController(DisplayController):
|
|||||||
Display the slide number passed
|
Display the slide number passed
|
||||||
"""
|
"""
|
||||||
log.debug(u'processManagerItem live = %s' % self.isLive)
|
log.debug(u'processManagerItem live = %s' % self.isLive)
|
||||||
self.onStopLoop()
|
self.on_stop_loop()
|
||||||
old_item = self.serviceItem
|
old_item = self.serviceItem
|
||||||
# take a copy not a link to the servicemanager copy.
|
# take a copy not a link to the servicemanager copy.
|
||||||
self.serviceItem = copy.copy(serviceItem)
|
self.serviceItem = copy.copy(serviceItem)
|
||||||
if old_item and self.isLive and old_item.is_capable(ItemCapabilities.ProvidesOwnDisplay):
|
if old_item and self.isLive and old_item.is_capable(ItemCapabilities.ProvidesOwnDisplay):
|
||||||
self._resetBlank()
|
self._resetBlank()
|
||||||
Receiver.send_message(u'%s_start' % serviceItem.name.lower(),
|
Registry().execute(u'%s_start' % serviceItem.name.lower(), [serviceItem, self.isLive, self.hideMode(), slideno])
|
||||||
[serviceItem, self.isLive, self.hideMode(), slideno])
|
|
||||||
self.slideList = {}
|
self.slideList = {}
|
||||||
width = self.parent().controlSplitter.sizes()[self.split]
|
width = self.parent().controlSplitter.sizes()[self.split]
|
||||||
self.previewListWidget.clear()
|
self.previewListWidget.clear()
|
||||||
@ -853,10 +842,10 @@ class SlideController(DisplayController):
|
|||||||
# However opening a new item of the same type will automatically
|
# However opening a new item of the same type will automatically
|
||||||
# close the previous, so make sure we don't close the new one.
|
# close the previous, so make sure we don't close the new one.
|
||||||
if old_item.is_command() and not serviceItem.is_command():
|
if old_item.is_command() and not serviceItem.is_command():
|
||||||
Receiver.send_message(u'%s_stop' % old_item.name.lower(), [old_item, self.isLive])
|
Registry().execute(u'%s_stop' % old_item.name.lower(), [old_item, self.isLive])
|
||||||
if old_item.is_media() and not serviceItem.is_media():
|
if old_item.is_media() and not serviceItem.is_media():
|
||||||
self.onMediaClose()
|
self.onMediaClose()
|
||||||
Receiver.send_message(u'slidecontroller_%s_started' % self.typePrefix, [serviceItem])
|
Registry().execute(u'slidecontroller_%s_started' % self.typePrefix, [serviceItem])
|
||||||
|
|
||||||
def __updatePreviewSelection(self, slideno):
|
def __updatePreviewSelection(self, slideno):
|
||||||
"""
|
"""
|
||||||
@ -869,7 +858,7 @@ class SlideController(DisplayController):
|
|||||||
self.__checkUpdateSelectedSlide(slideno)
|
self.__checkUpdateSelectedSlide(slideno)
|
||||||
|
|
||||||
# Screen event methods
|
# Screen event methods
|
||||||
def onSlideSelectedIndex(self, message):
|
def on_slide_selected_index(self, message):
|
||||||
"""
|
"""
|
||||||
Go to the requested slide
|
Go to the requested slide
|
||||||
"""
|
"""
|
||||||
@ -877,7 +866,7 @@ class SlideController(DisplayController):
|
|||||||
if not self.serviceItem:
|
if not self.serviceItem:
|
||||||
return
|
return
|
||||||
if self.serviceItem.is_command():
|
if self.serviceItem.is_command():
|
||||||
Receiver.send_message(u'%s_slide' % self.serviceItem.name.lower(), [self.serviceItem, self.isLive, index])
|
Registry().execute(u'%s_slide' % self.serviceItem.name.lower(), [self.serviceItem, self.isLive, index])
|
||||||
self.updatePreview()
|
self.updatePreview()
|
||||||
else:
|
else:
|
||||||
self.__checkUpdateSelectedSlide(index)
|
self.__checkUpdateSelectedSlide(index)
|
||||||
@ -898,17 +887,17 @@ class SlideController(DisplayController):
|
|||||||
elif display_type == u'blanked':
|
elif display_type == u'blanked':
|
||||||
self.onBlankDisplay(True)
|
self.onBlankDisplay(True)
|
||||||
else:
|
else:
|
||||||
Receiver.send_message(u'live_display_show')
|
Registry().execute(u'live_display_show')
|
||||||
else:
|
else:
|
||||||
self.liveEscape()
|
self.liveEscape()
|
||||||
|
|
||||||
def onSlideBlank(self):
|
def on_slide_blank(self):
|
||||||
"""
|
"""
|
||||||
Handle the slidecontroller blank event
|
Handle the slidecontroller blank event
|
||||||
"""
|
"""
|
||||||
self.onBlankDisplay(True)
|
self.onBlankDisplay(True)
|
||||||
|
|
||||||
def onSlideUnblank(self):
|
def on_slide_unblank(self):
|
||||||
"""
|
"""
|
||||||
Handle the slidecontroller unblank event
|
Handle the slidecontroller unblank event
|
||||||
"""
|
"""
|
||||||
@ -980,18 +969,18 @@ class SlideController(DisplayController):
|
|||||||
if self.serviceItem is not None:
|
if self.serviceItem is not None:
|
||||||
if hide_mode:
|
if hide_mode:
|
||||||
if not self.serviceItem.is_command():
|
if not self.serviceItem.is_command():
|
||||||
Receiver.send_message(u'live_display_hide', hide_mode)
|
Registry().execute(u'live_display_hide', hide_mode)
|
||||||
Receiver.send_message(u'%s_blank' % self.serviceItem.name.lower(),
|
Registry().execute(u'%s_blank' % self.serviceItem.name.lower(),
|
||||||
[self.serviceItem, self.isLive, hide_mode])
|
[self.serviceItem, self.isLive, hide_mode])
|
||||||
else:
|
else:
|
||||||
if not self.serviceItem.is_command():
|
if not self.serviceItem.is_command():
|
||||||
Receiver.send_message(u'live_display_show')
|
Registry().execute(u'live_display_show')
|
||||||
Receiver.send_message(u'%s_unblank' % self.serviceItem.name.lower(), [self.serviceItem, self.isLive])
|
Registry().execute(u'%s_unblank' % self.serviceItem.name.lower(), [self.serviceItem, self.isLive])
|
||||||
else:
|
else:
|
||||||
if hide_mode:
|
if hide_mode:
|
||||||
Receiver.send_message(u'live_display_hide', hide_mode)
|
Registry().execute(u'live_display_hide', hide_mode)
|
||||||
else:
|
else:
|
||||||
Receiver.send_message(u'live_display_show')
|
Registry().execute(u'live_display_show')
|
||||||
|
|
||||||
def hidePlugin(self, hide):
|
def hidePlugin(self, hide):
|
||||||
"""
|
"""
|
||||||
@ -1000,17 +989,17 @@ class SlideController(DisplayController):
|
|||||||
log.debug(u'hidePlugin %s ', hide)
|
log.debug(u'hidePlugin %s ', hide)
|
||||||
if self.serviceItem is not None:
|
if self.serviceItem is not None:
|
||||||
if hide:
|
if hide:
|
||||||
Receiver.send_message(u'live_display_hide', HideMode.Screen)
|
Registry().execute(u'live_display_hide', HideMode.Screen)
|
||||||
Receiver.send_message(u'%s_hide' % self.serviceItem.name.lower(), [self.serviceItem, self.isLive])
|
Registry().execute(u'%s_hide' % self.serviceItem.name.lower(), [self.serviceItem, self.isLive])
|
||||||
else:
|
else:
|
||||||
if not self.serviceItem.is_command():
|
if not self.serviceItem.is_command():
|
||||||
Receiver.send_message(u'live_display_show')
|
Registry().execute(u'live_display_show')
|
||||||
Receiver.send_message(u'%s_unblank' % self.serviceItem.name.lower(), [self.serviceItem, self.isLive])
|
Registry().execute(u'%s_unblank' % self.serviceItem.name.lower(), [self.serviceItem, self.isLive])
|
||||||
else:
|
else:
|
||||||
if hide:
|
if hide:
|
||||||
Receiver.send_message(u'live_display_hide', HideMode.Screen)
|
Registry().execute(u'live_display_hide', HideMode.Screen)
|
||||||
else:
|
else:
|
||||||
Receiver.send_message(u'live_display_show')
|
Registry().execute(u'live_display_show')
|
||||||
|
|
||||||
def onSlideSelected(self):
|
def onSlideSelected(self):
|
||||||
"""
|
"""
|
||||||
@ -1028,7 +1017,7 @@ class SlideController(DisplayController):
|
|||||||
if -1 < row < self.previewListWidget.rowCount():
|
if -1 < row < self.previewListWidget.rowCount():
|
||||||
if self.serviceItem.is_command():
|
if self.serviceItem.is_command():
|
||||||
if self.isLive and not start:
|
if self.isLive and not start:
|
||||||
Receiver.send_message(u'%s_slide' % self.serviceItem.name.lower(),
|
Registry().execute(u'%s_slide' % self.serviceItem.name.lower(),
|
||||||
[self.serviceItem, self.isLive, row])
|
[self.serviceItem, self.isLive, row])
|
||||||
else:
|
else:
|
||||||
to_display = self.serviceItem.get_rendered_frame(row)
|
to_display = self.serviceItem.get_rendered_frame(row)
|
||||||
@ -1044,16 +1033,16 @@ class SlideController(DisplayController):
|
|||||||
self.updatePreview()
|
self.updatePreview()
|
||||||
self.selectedRow = row
|
self.selectedRow = row
|
||||||
self.__checkUpdateSelectedSlide(row)
|
self.__checkUpdateSelectedSlide(row)
|
||||||
Receiver.send_message(u'slidecontroller_%s_changed' % self.typePrefix, row)
|
Registry().execute(u'slidecontroller_%s_changed' % self.typePrefix, row)
|
||||||
self.display.setFocus()
|
self.display.setFocus()
|
||||||
|
|
||||||
def onSlideChange(self, row):
|
def on_slide_change(self, row):
|
||||||
"""
|
"""
|
||||||
The slide has been changed. Update the slidecontroller accordingly
|
The slide has been changed. Update the slidecontroller accordingly
|
||||||
"""
|
"""
|
||||||
self.__checkUpdateSelectedSlide(row)
|
self.__checkUpdateSelectedSlide(row)
|
||||||
self.updatePreview()
|
self.updatePreview()
|
||||||
Receiver.send_message(u'slidecontroller_%s_changed' % self.typePrefix, row)
|
Registry().execute(u'slidecontroller_%s_changed' % self.typePrefix, row)
|
||||||
|
|
||||||
def updatePreview(self):
|
def updatePreview(self):
|
||||||
"""
|
"""
|
||||||
@ -1079,20 +1068,20 @@ class SlideController(DisplayController):
|
|||||||
winimg = QtGui.QPixmap.grabWindow(winid, rect.x(), rect.y(), rect.width(), rect.height())
|
winimg = QtGui.QPixmap.grabWindow(winid, rect.x(), rect.y(), rect.width(), rect.height())
|
||||||
self.slidePreview.setPixmap(winimg)
|
self.slidePreview.setPixmap(winimg)
|
||||||
|
|
||||||
def onSlideSelectedNextAction(self, checked):
|
def on_slide_selected_next_action(self, checked):
|
||||||
"""
|
"""
|
||||||
Wrapper function from create_action so we can throw away the
|
Wrapper function from create_action so we can throw away the
|
||||||
incorrect parameter
|
incorrect parameter
|
||||||
"""
|
"""
|
||||||
self.onSlideSelectedNext()
|
self.on_slide_selected_next()
|
||||||
|
|
||||||
def onSlideSelectedNext(self, wrap=None):
|
def on_slide_selected_next(self, wrap=None):
|
||||||
"""
|
"""
|
||||||
Go to the next slide.
|
Go to the next slide.
|
||||||
"""
|
"""
|
||||||
if not self.serviceItem:
|
if not self.serviceItem:
|
||||||
return
|
return
|
||||||
Receiver.send_message(u'%s_next' % self.serviceItem.name.lower(), [self.serviceItem, self.isLive])
|
Registry().execute(u'%s_next' % self.serviceItem.name.lower(), [self.serviceItem, self.isLive])
|
||||||
if self.serviceItem.is_command() and self.isLive:
|
if self.serviceItem.is_command() and self.isLive:
|
||||||
self.updatePreview()
|
self.updatePreview()
|
||||||
else:
|
else:
|
||||||
@ -1113,13 +1102,13 @@ class SlideController(DisplayController):
|
|||||||
self.__checkUpdateSelectedSlide(row)
|
self.__checkUpdateSelectedSlide(row)
|
||||||
self.slideSelected()
|
self.slideSelected()
|
||||||
|
|
||||||
def onSlideSelectedPrevious(self):
|
def on_slide_selected_previous(self):
|
||||||
"""
|
"""
|
||||||
Go to the previous slide.
|
Go to the previous slide.
|
||||||
"""
|
"""
|
||||||
if not self.serviceItem:
|
if not self.serviceItem:
|
||||||
return
|
return
|
||||||
Receiver.send_message(u'%s_previous' % self.serviceItem.name.lower(), [self.serviceItem, self.isLive])
|
Registry().execute(u'%s_previous' % self.serviceItem.name.lower(), [self.serviceItem, self.isLive])
|
||||||
if self.serviceItem.is_command() and self.isLive:
|
if self.serviceItem.is_command() and self.isLive:
|
||||||
self.updatePreview()
|
self.updatePreview()
|
||||||
else:
|
else:
|
||||||
@ -1152,7 +1141,7 @@ class SlideController(DisplayController):
|
|||||||
if hide_mode is None and (self.playSlidesLoop.isChecked() or self.playSlidesOnce.isChecked()):
|
if hide_mode is None and (self.playSlidesLoop.isChecked() or self.playSlidesOnce.isChecked()):
|
||||||
self.onStartLoop()
|
self.onStartLoop()
|
||||||
else:
|
else:
|
||||||
self.onStopLoop()
|
self.on_stop_loop()
|
||||||
|
|
||||||
def onStartLoop(self):
|
def onStartLoop(self):
|
||||||
"""
|
"""
|
||||||
@ -1161,7 +1150,7 @@ class SlideController(DisplayController):
|
|||||||
if self.previewListWidget.rowCount() > 1:
|
if self.previewListWidget.rowCount() > 1:
|
||||||
self.timer_id = self.startTimer(int(self.delaySpinBox.value()) * 1000)
|
self.timer_id = self.startTimer(int(self.delaySpinBox.value()) * 1000)
|
||||||
|
|
||||||
def onStopLoop(self):
|
def on_stop_loop(self):
|
||||||
"""
|
"""
|
||||||
Stop the timer loop running
|
Stop the timer loop running
|
||||||
"""
|
"""
|
||||||
@ -1233,7 +1222,7 @@ class SlideController(DisplayController):
|
|||||||
If the timer event is for this window select next slide
|
If the timer event is for this window select next slide
|
||||||
"""
|
"""
|
||||||
if event.timerId() == self.timer_id:
|
if event.timerId() == self.timer_id:
|
||||||
self.onSlideSelectedNext(self.playSlidesLoop.isChecked())
|
self.on_slide_selected_next(self.playSlidesLoop.isChecked())
|
||||||
|
|
||||||
def onEditSong(self):
|
def onEditSong(self):
|
||||||
"""
|
"""
|
||||||
@ -1259,7 +1248,7 @@ class SlideController(DisplayController):
|
|||||||
# Live and Preview have issues if we have video or presentations
|
# Live and Preview have issues if we have video or presentations
|
||||||
# playing in both at the same time.
|
# playing in both at the same time.
|
||||||
if self.serviceItem.is_command():
|
if self.serviceItem.is_command():
|
||||||
Receiver.send_message(u'%s_stop' % self.serviceItem.name.lower(), [self.serviceItem, self.isLive])
|
Registry().execute(u'%s_stop' % self.serviceItem.name.lower(), [self.serviceItem, self.isLive])
|
||||||
if self.serviceItem.is_media():
|
if self.serviceItem.is_media():
|
||||||
self.onMediaClose()
|
self.onMediaClose()
|
||||||
self.onGoLive()
|
self.onGoLive()
|
||||||
|
@ -34,7 +34,7 @@ import os
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, UiStrings, Registry, translate
|
from openlp.core.lib import UiStrings, Registry, translate
|
||||||
from openlp.core.lib.theme import BackgroundType, BackgroundGradientType
|
from openlp.core.lib.theme import BackgroundType, BackgroundGradientType
|
||||||
from openlp.core.lib.ui import critical_error_message_box
|
from openlp.core.lib.ui import critical_error_message_box
|
||||||
from openlp.core.ui import ThemeLayoutForm
|
from openlp.core.ui import ThemeLayoutForm
|
||||||
@ -88,7 +88,7 @@ class ThemeForm(QtGui.QWizard, Ui_ThemeWizard):
|
|||||||
QtCore.QObject.connect(self.footerPositionCheckBox, QtCore.SIGNAL(u'stateChanged(int)'),
|
QtCore.QObject.connect(self.footerPositionCheckBox, QtCore.SIGNAL(u'stateChanged(int)'),
|
||||||
self.onFooterPositionCheckBoxStateChanged)
|
self.onFooterPositionCheckBoxStateChanged)
|
||||||
QtCore.QObject.connect(self, QtCore.SIGNAL(u'currentIdChanged(int)'), self.onCurrentIdChanged)
|
QtCore.QObject.connect(self, QtCore.SIGNAL(u'currentIdChanged(int)'), self.onCurrentIdChanged)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'theme_line_count'), self.updateLinesText)
|
Registry().register_function(u'theme_line_count', self.updateLinesText)
|
||||||
QtCore.QObject.connect(self.mainSizeSpinBox, QtCore.SIGNAL(u'valueChanged(int)'), self.calculateLines)
|
QtCore.QObject.connect(self.mainSizeSpinBox, QtCore.SIGNAL(u'valueChanged(int)'), self.calculateLines)
|
||||||
QtCore.QObject.connect(self.lineSpacingSpinBox, QtCore.SIGNAL(u'valueChanged(int)'), self.calculateLines)
|
QtCore.QObject.connect(self.lineSpacingSpinBox, QtCore.SIGNAL(u'valueChanged(int)'), self.calculateLines)
|
||||||
QtCore.QObject.connect(self.outlineSizeSpinBox, QtCore.SIGNAL(u'valueChanged(int)'), self.calculateLines)
|
QtCore.QObject.connect(self.outlineSizeSpinBox, QtCore.SIGNAL(u'valueChanged(int)'), self.calculateLines)
|
||||||
|
@ -38,7 +38,7 @@ import re
|
|||||||
from xml.etree.ElementTree import ElementTree, XML
|
from xml.etree.ElementTree import ElementTree, XML
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import ImageSource, OpenLPToolbar, Receiver, Registry, SettingsManager, Settings, UiStrings, \
|
from openlp.core.lib import ImageSource, OpenLPToolbar, Registry, SettingsManager, Settings, UiStrings, \
|
||||||
get_text_file_string, build_icon, translate, check_item_selected, check_directory_exists, create_thumb, \
|
get_text_file_string, build_icon, translate, check_item_selected, check_directory_exists, create_thumb, \
|
||||||
validate_thumb
|
validate_thumb
|
||||||
from openlp.core.lib.theme import ThemeXML, BackgroundType, VerticalType, BackgroundGradientType
|
from openlp.core.lib.theme import ThemeXML, BackgroundType, VerticalType, BackgroundGradientType
|
||||||
@ -125,18 +125,17 @@ class ThemeManager(QtGui.QWidget):
|
|||||||
self.global_action = create_widget_action(self.menu,
|
self.global_action = create_widget_action(self.menu,
|
||||||
text=translate('OpenLP.ThemeManager', 'Set As &Global Default'),
|
text=translate('OpenLP.ThemeManager', 'Set As &Global Default'),
|
||||||
icon=u':/general/general_export.png',
|
icon=u':/general/general_export.png',
|
||||||
triggers=self.changeGlobalFromScreen)
|
triggers=self.change_global_from_screen)
|
||||||
self.exportAction = create_widget_action(self.menu,
|
self.exportAction = create_widget_action(self.menu,
|
||||||
text=translate('OpenLP.ThemeManager', '&Export Theme'),
|
text=translate('OpenLP.ThemeManager', '&Export Theme'),
|
||||||
icon=u':/general/general_export.png', triggers=self.on_export_theme)
|
icon=u':/general/general_export.png', triggers=self.on_export_theme)
|
||||||
# Signals
|
# Signals
|
||||||
QtCore.QObject.connect(self.theme_list_widget,
|
QtCore.QObject.connect(self.theme_list_widget,
|
||||||
QtCore.SIGNAL(u'doubleClicked(QModelIndex)'), self.changeGlobalFromScreen)
|
QtCore.SIGNAL(u'doubleClicked(QModelIndex)'), self.change_global_from_screen)
|
||||||
QtCore.QObject.connect(self.theme_list_widget,
|
QtCore.QObject.connect(self.theme_list_widget,
|
||||||
QtCore.SIGNAL(u'currentItemChanged(QListWidgetItem *, QListWidgetItem *)'), self.check_list_state)
|
QtCore.SIGNAL(u'currentItemChanged(QListWidgetItem *, QListWidgetItem *)'), self.check_list_state)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
Registry().register_function(u'theme_update_global', self.change_global_from_tab)
|
||||||
QtCore.SIGNAL(u'theme_update_global'), self.change_global_from_tab)
|
Registry().register_function(u'config_updated', self.config_updated)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'config_updated'), self.config_updated)
|
|
||||||
# Variables
|
# Variables
|
||||||
self.theme_list = []
|
self.theme_list = []
|
||||||
self.path = AppLocation.get_section_data_path(self.settingsSection)
|
self.path = AppLocation.get_section_data_path(self.settingsSection)
|
||||||
@ -166,6 +165,7 @@ class ThemeManager(QtGui.QWidget):
|
|||||||
"""
|
"""
|
||||||
Triggered when Config dialog is updated.
|
Triggered when Config dialog is updated.
|
||||||
"""
|
"""
|
||||||
|
log.debug(u'config_updated')
|
||||||
self.global_theme = Settings().value(self.settingsSection + u'/global theme')
|
self.global_theme = Settings().value(self.settingsSection + u'/global theme')
|
||||||
|
|
||||||
def check_list_state(self, item):
|
def check_list_state(self, item):
|
||||||
@ -215,15 +215,14 @@ class ThemeManager(QtGui.QWidget):
|
|||||||
if theme_name == new_name:
|
if theme_name == new_name:
|
||||||
name = translate('OpenLP.ThemeManager', '%s (default)') % new_name
|
name = translate('OpenLP.ThemeManager', '%s (default)') % new_name
|
||||||
self.theme_list_widget.item(count).setText(name)
|
self.theme_list_widget.item(count).setText(name)
|
||||||
self.deleteToolbarAction.setVisible(
|
self.deleteToolbarAction.setVisible(item not in self.theme_list_widget.selectedItems())
|
||||||
item not in self.theme_list_widget.selectedItems())
|
|
||||||
|
|
||||||
def changeGlobalFromScreen(self, index=-1):
|
def change_global_from_screen(self, index=-1):
|
||||||
"""
|
"""
|
||||||
Change the global theme when a theme is double clicked upon in the
|
Change the global theme when a theme is double clicked upon in the
|
||||||
Theme Manager list
|
Theme Manager list
|
||||||
"""
|
"""
|
||||||
log.debug(u'changeGlobalFromScreen %s', index)
|
log.debug(u'change_global_from_screen %s', index)
|
||||||
selected_row = self.theme_list_widget.currentRow()
|
selected_row = self.theme_list_widget.currentRow()
|
||||||
for count in range(0, self.theme_list_widget.count()):
|
for count in range(0, self.theme_list_widget.count()):
|
||||||
item = self.theme_list_widget.item(count)
|
item = self.theme_list_widget.item(count)
|
||||||
@ -237,7 +236,7 @@ class ThemeManager(QtGui.QWidget):
|
|||||||
name = translate('OpenLP.ThemeManager', '%s (default)') % self.global_theme
|
name = translate('OpenLP.ThemeManager', '%s (default)') % self.global_theme
|
||||||
self.theme_list_widget.item(count).setText(name)
|
self.theme_list_widget.item(count).setText(name)
|
||||||
Settings().setValue(self.settingsSection + u'/global theme', self.global_theme)
|
Settings().setValue(self.settingsSection + u'/global theme', self.global_theme)
|
||||||
Receiver.send_message(u'theme_update_global', self.global_theme)
|
Registry().execute(u'theme_update_global', self.global_theme)
|
||||||
self._push_themes()
|
self._push_themes()
|
||||||
|
|
||||||
def onAddTheme(self):
|
def onAddTheme(self):
|
||||||
@ -464,12 +463,13 @@ class ThemeManager(QtGui.QWidget):
|
|||||||
"""
|
"""
|
||||||
Notify listeners that the theme list has been updated
|
Notify listeners that the theme list has been updated
|
||||||
"""
|
"""
|
||||||
Receiver.send_message(u'theme_update_list', self.get_themes())
|
Registry().execute(u'theme_update_list', self.get_themes())
|
||||||
|
|
||||||
def get_themes(self):
|
def get_themes(self):
|
||||||
"""
|
"""
|
||||||
Return the list of loaded themes
|
Return the list of loaded themes
|
||||||
"""
|
"""
|
||||||
|
log.debug(u'get themes')
|
||||||
return self.theme_list
|
return self.theme_list
|
||||||
|
|
||||||
def get_theme_data(self, theme_name):
|
def get_theme_data(self, theme_name):
|
||||||
@ -479,7 +479,7 @@ class ThemeManager(QtGui.QWidget):
|
|||||||
``theme_name``
|
``theme_name``
|
||||||
Name of the theme to load from file
|
Name of the theme to load from file
|
||||||
"""
|
"""
|
||||||
log.debug(u'getthemedata for theme %s', theme_name)
|
log.debug(u'get theme data for theme %s', theme_name)
|
||||||
xml_file = os.path.join(self.path, unicode(theme_name), unicode(theme_name) + u'.xml')
|
xml_file = os.path.join(self.path, unicode(theme_name), unicode(theme_name) + u'.xml')
|
||||||
xml = get_text_file_string(xml_file)
|
xml = get_text_file_string(xml_file)
|
||||||
if not xml:
|
if not xml:
|
||||||
@ -687,6 +687,7 @@ class ThemeManager(QtGui.QWidget):
|
|||||||
"""
|
"""
|
||||||
Called to update the themes' preview images.
|
Called to update the themes' preview images.
|
||||||
"""
|
"""
|
||||||
|
log.debug('update_preview_images')
|
||||||
self.main_window.displayProgressBar(len(self.theme_list))
|
self.main_window.displayProgressBar(len(self.theme_list))
|
||||||
for theme in self.theme_list:
|
for theme in self.theme_list:
|
||||||
self.main_window.incrementProgressBar()
|
self.main_window.incrementProgressBar()
|
||||||
|
@ -31,7 +31,7 @@ The Themes configuration tab
|
|||||||
"""
|
"""
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, Settings, SettingsTab, UiStrings, translate
|
from openlp.core.lib import Registry, Settings, SettingsTab, UiStrings, translate
|
||||||
from openlp.core.lib.theme import ThemeLevel
|
from openlp.core.lib.theme import ThemeLevel
|
||||||
from openlp.core.lib.ui import find_and_set_in_combo_box
|
from openlp.core.lib.ui import find_and_set_in_combo_box
|
||||||
|
|
||||||
@ -104,7 +104,7 @@ class ThemesTab(SettingsTab):
|
|||||||
QtCore.QObject.connect(self.GlobalLevelRadioButton, QtCore.SIGNAL(u'clicked()'),
|
QtCore.QObject.connect(self.GlobalLevelRadioButton, QtCore.SIGNAL(u'clicked()'),
|
||||||
self.onGlobalLevelButtonClicked)
|
self.onGlobalLevelButtonClicked)
|
||||||
QtCore.QObject.connect(self.DefaultComboBox, QtCore.SIGNAL(u'activated(int)'), self.onDefaultComboBoxChanged)
|
QtCore.QObject.connect(self.DefaultComboBox, QtCore.SIGNAL(u'activated(int)'), self.onDefaultComboBoxChanged)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'theme_update_list'), self.updateThemeList)
|
Registry().register_function(u'theme_update_list', self.update_theme_list)
|
||||||
|
|
||||||
def retranslateUi(self):
|
def retranslateUi(self):
|
||||||
"""
|
"""
|
||||||
@ -153,13 +153,13 @@ class ThemesTab(SettingsTab):
|
|||||||
settings.endGroup()
|
settings.endGroup()
|
||||||
self.renderer.set_global_theme(self.global_theme)
|
self.renderer.set_global_theme(self.global_theme)
|
||||||
self.renderer.set_theme_level(self.theme_level)
|
self.renderer.set_theme_level(self.theme_level)
|
||||||
Receiver.send_message(u'theme_update_global', self.global_theme)
|
Registry().execute(u'theme_update_global', self.global_theme)
|
||||||
|
|
||||||
def postSetUp(self):
|
def postSetUp(self):
|
||||||
"""
|
"""
|
||||||
After setting things up...
|
After setting things up...
|
||||||
"""
|
"""
|
||||||
Receiver.send_message(u'theme_update_global', self.global_theme)
|
Registry().execute(u'theme_update_global', self.global_theme)
|
||||||
|
|
||||||
def onSongLevelButtonClicked(self):
|
def onSongLevelButtonClicked(self):
|
||||||
"""
|
"""
|
||||||
@ -187,7 +187,7 @@ class ThemesTab(SettingsTab):
|
|||||||
self.renderer.set_global_theme(self.global_theme)
|
self.renderer.set_global_theme(self.global_theme)
|
||||||
self.__previewGlobalTheme()
|
self.__previewGlobalTheme()
|
||||||
|
|
||||||
def updateThemeList(self, theme_list):
|
def update_theme_list(self, theme_list):
|
||||||
"""
|
"""
|
||||||
Called from ThemeManager when the Themes have changed.
|
Called from ThemeManager when the Themes have changed.
|
||||||
|
|
||||||
|
@ -34,7 +34,7 @@ import os
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, Registry, Settings, UiStrings, build_icon, translate
|
from openlp.core.lib import Registry, Settings, UiStrings, build_icon, translate
|
||||||
from openlp.core.lib.ui import add_welcome_page
|
from openlp.core.lib.ui import add_welcome_page
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
@ -192,7 +192,7 @@ class OpenLPWizard(QtGui.QWizard):
|
|||||||
"""
|
"""
|
||||||
log.debug(u'Wizard cancelled by user.')
|
log.debug(u'Wizard cancelled by user.')
|
||||||
if self.withProgressPage and self.currentPage() == self.progressPage:
|
if self.withProgressPage and self.currentPage() == self.progressPage:
|
||||||
Receiver.send_message(u'openlp_stop_wizard')
|
Registry().execute(u'openlp_stop_wizard')
|
||||||
self.done(QtGui.QDialog.Rejected)
|
self.done(QtGui.QDialog.Rejected)
|
||||||
|
|
||||||
def onCurrentIdChanged(self, pageId):
|
def onCurrentIdChanged(self, pageId):
|
||||||
|
@ -51,7 +51,7 @@ if sys.platform != u'win32' and sys.platform != u'darwin':
|
|||||||
XDG_BASE_AVAILABLE = False
|
XDG_BASE_AVAILABLE = False
|
||||||
|
|
||||||
import openlp
|
import openlp
|
||||||
from openlp.core.lib import Receiver, translate, check_directory_exists
|
from openlp.core.lib import translate, check_directory_exists
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
APPLICATION_VERSION = {}
|
APPLICATION_VERSION = {}
|
||||||
@ -72,11 +72,11 @@ class VersionThread(QtCore.QThread):
|
|||||||
Run the thread.
|
Run the thread.
|
||||||
"""
|
"""
|
||||||
self.sleep(1)
|
self.sleep(1)
|
||||||
|
log.debug(u'Version thread - run')
|
||||||
app_version = get_application_version()
|
app_version = get_application_version()
|
||||||
version = check_latest_version(app_version)
|
version = check_latest_version(app_version)
|
||||||
if LooseVersion(str(version)) > LooseVersion(str(app_version[u'full'])):
|
if LooseVersion(str(version)) > LooseVersion(str(app_version[u'full'])):
|
||||||
Receiver.send_message(u'openlp_version_check', u'%s' % version)
|
Registry().execute(u'openlp_version_check', u'%s' % version)
|
||||||
|
|
||||||
|
|
||||||
class AppLocation(object):
|
class AppLocation(object):
|
||||||
"""
|
"""
|
||||||
@ -288,6 +288,8 @@ def check_latest_version(current_version):
|
|||||||
this_test = datetime.now().date()
|
this_test = datetime.now().date()
|
||||||
settings.setValue(u'last version test', this_test)
|
settings.setValue(u'last version test', this_test)
|
||||||
settings.endGroup()
|
settings.endGroup()
|
||||||
|
# Tell the main window whether there will ever be data to display
|
||||||
|
Registry().get(u'main_window').version_update_running = last_test != this_test
|
||||||
if last_test != this_test:
|
if last_test != this_test:
|
||||||
if current_version[u'build']:
|
if current_version[u'build']:
|
||||||
req = urllib2.Request(u'http://www.openlp.org/files/nightly_version.txt')
|
req = urllib2.Request(u'http://www.openlp.org/files/nightly_version.txt')
|
||||||
|
@ -35,7 +35,7 @@ import logging
|
|||||||
|
|
||||||
from PyQt4 import QtCore
|
from PyQt4 import QtCore
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, translate
|
from openlp.core.lib import Registry, translate
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
@ -49,19 +49,19 @@ class AlertsManager(QtCore.QObject):
|
|||||||
QtCore.QObject.__init__(self, parent)
|
QtCore.QObject.__init__(self, parent)
|
||||||
self.screen = None
|
self.screen = None
|
||||||
self.timer_id = 0
|
self.timer_id = 0
|
||||||
self.alertList = []
|
self.alert_list = []
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'live_display_active'), self.generateAlert)
|
Registry().register_function(u'live_display_active', self.generate_alert)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'alerts_text'), self.onAlertText)
|
Registry().register_function(u'alerts_text', self.alert_text)
|
||||||
|
|
||||||
def onAlertText(self, message):
|
def alert_text(self, message):
|
||||||
"""
|
"""
|
||||||
Called via a alerts_text event. Message is single element array
|
Called via a alerts_text event. Message is single element array
|
||||||
containing text
|
containing text
|
||||||
"""
|
"""
|
||||||
if message:
|
if message:
|
||||||
self.displayAlert(message[0])
|
self.display_alert(message[0])
|
||||||
|
|
||||||
def displayAlert(self, text=u''):
|
def display_alert(self, text=u''):
|
||||||
"""
|
"""
|
||||||
Called from the Alert Tab to display an alert
|
Called from the Alert Tab to display an alert
|
||||||
|
|
||||||
@ -70,22 +70,22 @@ class AlertsManager(QtCore.QObject):
|
|||||||
"""
|
"""
|
||||||
log.debug(u'display alert called %s' % text)
|
log.debug(u'display alert called %s' % text)
|
||||||
if text:
|
if text:
|
||||||
self.alertList.append(text)
|
self.alert_list.append(text)
|
||||||
if self.timer_id != 0:
|
if self.timer_id != 0:
|
||||||
Receiver.send_message(u'mainwindow_status_text',
|
self.main_window.show_status_message(
|
||||||
translate('AlertsPlugin.AlertsManager', 'Alert message created and displayed.'))
|
translate('AlertsPlugin.AlertsManager', 'Alert message created and displayed.'))
|
||||||
return
|
return
|
||||||
Receiver.send_message(u'mainwindow_status_text', u'')
|
self.main_window.show_status_message(u'')
|
||||||
self.generateAlert()
|
self.generate_alert()
|
||||||
|
|
||||||
def generateAlert(self):
|
def generate_alert(self):
|
||||||
"""
|
"""
|
||||||
Format and request the Alert and start the timer
|
Format and request the Alert and start the timer
|
||||||
"""
|
"""
|
||||||
log.debug(u'Generate Alert called')
|
log.debug(u'Generate Alert called')
|
||||||
if not self.alertList:
|
if not self.alert_list:
|
||||||
return
|
return
|
||||||
text = self.alertList.pop(0)
|
text = self.alert_list.pop(0)
|
||||||
alertTab = self.parent().settingsTab
|
alertTab = self.parent().settingsTab
|
||||||
self.parent().liveController.display.alert(text, alertTab.location)
|
self.parent().liveController.display.alert(text, alertTab.location)
|
||||||
# Check to see if we have a timer running.
|
# Check to see if we have a timer running.
|
||||||
@ -106,4 +106,14 @@ class AlertsManager(QtCore.QObject):
|
|||||||
self.parent().liveController.display.alert(u'', alertTab.location)
|
self.parent().liveController.display.alert(u'', alertTab.location)
|
||||||
self.killTimer(self.timer_id)
|
self.killTimer(self.timer_id)
|
||||||
self.timer_id = 0
|
self.timer_id = 0
|
||||||
self.generateAlert()
|
self.generate_alert()
|
||||||
|
|
||||||
|
def _get_main_window(self):
|
||||||
|
"""
|
||||||
|
Adds the main window to the class dynamically
|
||||||
|
"""
|
||||||
|
if not hasattr(self, u'_main_window'):
|
||||||
|
self._main_window = Registry().get(u'main_window')
|
||||||
|
return self._main_window
|
||||||
|
|
||||||
|
main_window = property(_get_main_window)
|
@ -29,7 +29,7 @@
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import SettingsTab, Receiver, Settings, UiStrings, translate
|
from openlp.core.lib import Registry, SettingsTab, Settings, UiStrings, translate
|
||||||
from openlp.core.lib.ui import create_valign_selection_widgets
|
from openlp.core.lib.ui import create_valign_selection_widgets
|
||||||
|
|
||||||
class AlertsTab(SettingsTab):
|
class AlertsTab(SettingsTab):
|
||||||
@ -174,7 +174,7 @@ class AlertsTab(SettingsTab):
|
|||||||
settings.setValue(u'location', self.location)
|
settings.setValue(u'location', self.location)
|
||||||
settings.endGroup()
|
settings.endGroup()
|
||||||
if self.changed:
|
if self.changed:
|
||||||
Receiver.send_message(u'update_display_css')
|
Registry().execute(u'update_display_css')
|
||||||
self.changed = False
|
self.changed = False
|
||||||
|
|
||||||
def updateDisplay(self):
|
def updateDisplay(self):
|
||||||
|
@ -36,7 +36,7 @@ from tempfile import gettempdir
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, Settings, UiStrings, translate, check_directory_exists
|
from openlp.core.lib import Registry, Settings, UiStrings, translate, check_directory_exists
|
||||||
from openlp.core.lib.ui import critical_error_message_box
|
from openlp.core.lib.ui import critical_error_message_box
|
||||||
from openlp.core.ui.wizard import OpenLPWizard, WizardStrings
|
from openlp.core.ui.wizard import OpenLPWizard, WizardStrings
|
||||||
from openlp.core.utils import AppLocation, delete_file, get_filesystem_encoding
|
from openlp.core.utils import AppLocation, delete_file, get_filesystem_encoding
|
||||||
@ -82,7 +82,7 @@ class BibleUpgradeForm(OpenLPWizard):
|
|||||||
Set up the UI for the bible wizard.
|
Set up the UI for the bible wizard.
|
||||||
"""
|
"""
|
||||||
OpenLPWizard.setupUi(self, image)
|
OpenLPWizard.setupUi(self, image)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'openlp_stop_wizard'), self.stop_import)
|
Registry().execute(u'openlp_stop_wizard', self.stop_import)
|
||||||
|
|
||||||
def stop_import(self):
|
def stop_import(self):
|
||||||
"""
|
"""
|
||||||
|
@ -31,7 +31,7 @@ import logging
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, SettingsTab, Settings, UiStrings, translate
|
from openlp.core.lib import Registry, SettingsTab, Settings, UiStrings, translate
|
||||||
from openlp.core.lib.ui import find_and_set_in_combo_box
|
from openlp.core.lib.ui import find_and_set_in_combo_box
|
||||||
from openlp.plugins.bibles.lib import LayoutStyle, DisplayStyle, update_reference_separators, \
|
from openlp.plugins.bibles.lib import LayoutStyle, DisplayStyle, update_reference_separators, \
|
||||||
get_reference_separator, LanguageSelection
|
get_reference_separator, LanguageSelection
|
||||||
@ -168,7 +168,7 @@ class BiblesTab(SettingsTab):
|
|||||||
self.onEndSeparatorLineEditEdited)
|
self.onEndSeparatorLineEditEdited)
|
||||||
QtCore.QObject.connect(self.endSeparatorLineEdit, QtCore.SIGNAL(u'editingFinished()'),
|
QtCore.QObject.connect(self.endSeparatorLineEdit, QtCore.SIGNAL(u'editingFinished()'),
|
||||||
self.onEndSeparatorLineEditFinished)
|
self.onEndSeparatorLineEditFinished)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'theme_update_list'), self.updateThemeList)
|
Registry().register_function(u'theme_update_list', self.update_theme_list)
|
||||||
QtCore.QObject.connect(self.languageSelectionComboBox, QtCore.SIGNAL(u'activated(int)'),
|
QtCore.QObject.connect(self.languageSelectionComboBox, QtCore.SIGNAL(u'activated(int)'),
|
||||||
self.onLanguageSelectionComboBoxChanged)
|
self.onLanguageSelectionComboBoxChanged)
|
||||||
|
|
||||||
@ -406,10 +406,10 @@ class BiblesTab(SettingsTab):
|
|||||||
else:
|
else:
|
||||||
settings.remove(u'end separator')
|
settings.remove(u'end separator')
|
||||||
update_reference_separators()
|
update_reference_separators()
|
||||||
Receiver.send_message(u'bibles_load_list')
|
Registry().execute(u'bibles_load_list')
|
||||||
settings.endGroup()
|
settings.endGroup()
|
||||||
|
|
||||||
def updateThemeList(self, theme_list):
|
def update_theme_list(self, theme_list):
|
||||||
"""
|
"""
|
||||||
Called from ThemeManager when the Themes have changed.
|
Called from ThemeManager when the Themes have changed.
|
||||||
|
|
||||||
|
@ -38,7 +38,7 @@ from sqlalchemy import Column, ForeignKey, Table, or_, types, func
|
|||||||
from sqlalchemy.orm import class_mapper, mapper, relation
|
from sqlalchemy.orm import class_mapper, mapper, relation
|
||||||
from sqlalchemy.orm.exc import UnmappedClassError
|
from sqlalchemy.orm.exc import UnmappedClassError
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, Registry, translate
|
from openlp.core.lib import Registry, translate
|
||||||
from openlp.core.lib.db import BaseModel, init_db, Manager
|
from openlp.core.lib.db import BaseModel, init_db, Manager
|
||||||
from openlp.core.lib.ui import critical_error_message_box
|
from openlp.core.lib.ui import critical_error_message_box
|
||||||
from openlp.core.utils import AppLocation, clean_filename
|
from openlp.core.utils import AppLocation, clean_filename
|
||||||
@ -160,7 +160,7 @@ class BibleDB(QtCore.QObject, Manager):
|
|||||||
if u'path' in kwargs:
|
if u'path' in kwargs:
|
||||||
self.path = kwargs[u'path']
|
self.path = kwargs[u'path']
|
||||||
self.wizard = None
|
self.wizard = None
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'openlp_stop_wizard'), self.stop_import)
|
Registry().execute(u'openlp_stop_wizard', self.stop_import)
|
||||||
|
|
||||||
def stop_import(self):
|
def stop_import(self):
|
||||||
"""
|
"""
|
||||||
|
@ -234,10 +234,8 @@ class BGExtract(object):
|
|||||||
soup = get_soup_for_bible_ref(
|
soup = get_soup_for_bible_ref(
|
||||||
u'http://www.biblegateway.com/passage/?%s' % url_params,
|
u'http://www.biblegateway.com/passage/?%s' % url_params,
|
||||||
pre_parse_regex=r'<meta name.*?/>', pre_parse_substitute='', cleaner=cleaner)
|
pre_parse_regex=r'<meta name.*?/>', pre_parse_substitute='', cleaner=cleaner)
|
||||||
self.application.process_events()
|
|
||||||
if not soup:
|
if not soup:
|
||||||
return None
|
return None
|
||||||
self.application.process_events()
|
|
||||||
div = soup.find('div', 'result-text-style-normal')
|
div = soup.find('div', 'result-text-style-normal')
|
||||||
self._clean_soup(div)
|
self._clean_soup(div)
|
||||||
span_list = div.findAll('span', 'text')
|
span_list = div.findAll('span', 'text')
|
||||||
@ -296,6 +294,16 @@ class BGExtract(object):
|
|||||||
books.append(book.contents[0])
|
books.append(book.contents[0])
|
||||||
return books
|
return books
|
||||||
|
|
||||||
|
def _get_application(self):
|
||||||
|
"""
|
||||||
|
Adds the openlp to the class dynamically
|
||||||
|
"""
|
||||||
|
if not hasattr(self, u'_application'):
|
||||||
|
self._application = Registry().get(u'application')
|
||||||
|
return self._application
|
||||||
|
|
||||||
|
application = property(_get_application)
|
||||||
|
|
||||||
|
|
||||||
class BSExtract(object):
|
class BSExtract(object):
|
||||||
"""
|
"""
|
||||||
@ -457,6 +465,16 @@ class CWExtract(object):
|
|||||||
books.append(book.contents[0])
|
books.append(book.contents[0])
|
||||||
return books
|
return books
|
||||||
|
|
||||||
|
def _get_application(self):
|
||||||
|
"""
|
||||||
|
Adds the openlp to the class dynamically
|
||||||
|
"""
|
||||||
|
if not hasattr(self, u'_application'):
|
||||||
|
self._application = Registry().get(u'application')
|
||||||
|
return self._application
|
||||||
|
|
||||||
|
application = property(_get_application)
|
||||||
|
|
||||||
|
|
||||||
class HTTPBible(BibleDB):
|
class HTTPBible(BibleDB):
|
||||||
log.info(u'%s HTTPBible loaded', __name__)
|
log.info(u'%s HTTPBible loaded', __name__)
|
||||||
|
@ -30,7 +30,7 @@
|
|||||||
import logging
|
import logging
|
||||||
import os
|
import os
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, SettingsManager, Settings, translate
|
from openlp.core.lib import Registry, SettingsManager, Settings, translate
|
||||||
from openlp.core.utils import AppLocation, delete_file
|
from openlp.core.utils import AppLocation, delete_file
|
||||||
from openlp.plugins.bibles.lib import parse_reference, get_reference_separator, LanguageSelection
|
from openlp.plugins.bibles.lib import parse_reference, get_reference_separator, LanguageSelection
|
||||||
from openlp.plugins.bibles.lib.db import BibleDB, BibleMeta
|
from openlp.plugins.bibles.lib.db import BibleDB, BibleMeta
|
||||||
@ -304,12 +304,12 @@ class BibleManager(object):
|
|||||||
log.debug(u'BibleManager.get_verses("%s", "%s")', bible, versetext)
|
log.debug(u'BibleManager.get_verses("%s", "%s")', bible, versetext)
|
||||||
if not bible:
|
if not bible:
|
||||||
if show_error:
|
if show_error:
|
||||||
Receiver.send_message(u'openlp_information_message', {
|
self.main_window.information_message(
|
||||||
u'title': translate('BiblesPlugin.BibleManager', 'No Bibles Available'),
|
translate('BiblesPlugin.BibleManager', 'No Bibles Available'),
|
||||||
u'message': translate('BiblesPlugin.BibleManager',
|
translate('BiblesPlugin.BibleManager',
|
||||||
'There are no Bibles currently installed. Please use the '
|
'There are no Bibles currently installed. Please use the '
|
||||||
'Import Wizard to install one or more Bibles.')
|
'Import Wizard to install one or more Bibles.')
|
||||||
})
|
)
|
||||||
return None
|
return None
|
||||||
language_selection = self.get_language_selection(bible)
|
language_selection = self.get_language_selection(bible)
|
||||||
reflist = parse_reference(versetext, self.db_cache[bible],
|
reflist = parse_reference(versetext, self.db_cache[bible],
|
||||||
@ -322,14 +322,11 @@ class BibleManager(object):
|
|||||||
u'verse': get_reference_separator(u'sep_v_display'),
|
u'verse': get_reference_separator(u'sep_v_display'),
|
||||||
u'range': get_reference_separator(u'sep_r_display'),
|
u'range': get_reference_separator(u'sep_r_display'),
|
||||||
u'list': get_reference_separator(u'sep_l_display')}
|
u'list': get_reference_separator(u'sep_l_display')}
|
||||||
Receiver.send_message(u'openlp_information_message', {
|
self.main_window.information_message(
|
||||||
u'title': translate('BiblesPlugin.BibleManager',
|
translate('BiblesPlugin.BibleManager', 'Scripture Reference Error'),
|
||||||
'Scripture Reference Error'),
|
translate('BiblesPlugin.BibleManager', 'Your scripture reference is either not supported by '
|
||||||
u'message': translate('BiblesPlugin.BibleManager',
|
|
||||||
'Your scripture reference is either not supported by '
|
|
||||||
'OpenLP or is invalid. Please make sure your reference '
|
'OpenLP or is invalid. Please make sure your reference '
|
||||||
'conforms to one of the following patterns or consult the '
|
'conforms to one of the following patterns or consult the manual:\n\n'
|
||||||
'manual:\n\n'
|
|
||||||
'Book Chapter\n'
|
'Book Chapter\n'
|
||||||
'Book Chapter%(range)sChapter\n'
|
'Book Chapter%(range)sChapter\n'
|
||||||
'Book Chapter%(verse)sVerse%(range)sVerse\n'
|
'Book Chapter%(verse)sVerse%(range)sVerse\n'
|
||||||
@ -339,9 +336,8 @@ class BibleManager(object):
|
|||||||
'%(verse)sVerse%(range)sVerse\n'
|
'%(verse)sVerse%(range)sVerse\n'
|
||||||
'Book Chapter%(verse)sVerse%(range)sChapter%(verse)sVerse',
|
'Book Chapter%(verse)sVerse%(range)sChapter%(verse)sVerse',
|
||||||
'Please pay attention to the appended "s" of the wildcards '
|
'Please pay attention to the appended "s" of the wildcards '
|
||||||
'and refrain from translating the words inside the '
|
'and refrain from translating the words inside the names in the brackets.') % reference_seperators
|
||||||
'names in the brackets.') % reference_seperators
|
)
|
||||||
})
|
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def get_language_selection(self, bible):
|
def get_language_selection(self, bible):
|
||||||
@ -380,36 +376,33 @@ class BibleManager(object):
|
|||||||
"""
|
"""
|
||||||
log.debug(u'BibleManager.verse_search("%s", "%s")', bible, text)
|
log.debug(u'BibleManager.verse_search("%s", "%s")', bible, text)
|
||||||
if not bible:
|
if not bible:
|
||||||
Receiver.send_message(u'openlp_information_message', {
|
self.main_window.information_message(
|
||||||
u'title': translate('BiblesPlugin.BibleManager', 'No Bibles Available'),
|
translate('BiblesPlugin.BibleManager', 'No Bibles Available'),
|
||||||
u'message': translate('BiblesPlugin.BibleManager',
|
translate('BiblesPlugin.BibleManager',
|
||||||
'There are no Bibles currently installed. Please use the '
|
'There are no Bibles currently installed. Please use the Import Wizard to install one or more'
|
||||||
'Import Wizard to install one or more Bibles.')
|
' Bibles.')
|
||||||
})
|
)
|
||||||
return None
|
return None
|
||||||
# Check if the bible or second_bible is a web bible.
|
# Check if the bible or second_bible is a web bible.
|
||||||
webbible = self.db_cache[bible].get_object(BibleMeta,
|
webbible = self.db_cache[bible].get_object(BibleMeta, u'download_source')
|
||||||
u'download_source')
|
|
||||||
second_webbible = u''
|
second_webbible = u''
|
||||||
if second_bible:
|
if second_bible:
|
||||||
second_webbible = self.db_cache[second_bible].get_object(BibleMeta,
|
second_webbible = self.db_cache[second_bible].get_object(BibleMeta, u'download_source')
|
||||||
u'download_source')
|
|
||||||
if webbible or second_webbible:
|
if webbible or second_webbible:
|
||||||
Receiver.send_message(u'openlp_information_message', {
|
self.main_window.information_message(
|
||||||
u'title': translate('BiblesPlugin.BibleManager', 'Web Bible cannot be used'),
|
translate('BiblesPlugin.BibleManager', 'Web Bible cannot be used'),
|
||||||
u'message': translate('BiblesPlugin.BibleManager', 'Text Search is not available with Web Bibles.')
|
translate('BiblesPlugin.BibleManager', 'Text Search is not available with Web Bibles.')
|
||||||
})
|
)
|
||||||
return None
|
return None
|
||||||
if text:
|
if text:
|
||||||
return self.db_cache[bible].verse_search(text)
|
return self.db_cache[bible].verse_search(text)
|
||||||
else:
|
else:
|
||||||
Receiver.send_message(u'openlp_information_message', {
|
self.main_window.information_message(
|
||||||
u'title': translate('BiblesPlugin.BibleManager', 'Scripture Reference Error'),
|
translate('BiblesPlugin.BibleManager', 'Scripture Reference Error'),
|
||||||
u'message': translate('BiblesPlugin.BibleManager', 'You did not enter a search keyword.\n'
|
translate('BiblesPlugin.BibleManager', 'You did not enter a search keyword.\nYou can separate '
|
||||||
'You can separate different keywords by a space to '
|
'different keywords by a space to search for all of your keywords and you can separate '
|
||||||
'search for all of your keywords and you can separate '
|
|
||||||
'them by a comma to search for one of them.')
|
'them by a comma to search for one of them.')
|
||||||
})
|
)
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def save_meta_data(self, bible, version, copyright, permissions,
|
def save_meta_data(self, bible, version, copyright, permissions,
|
||||||
@ -460,6 +453,16 @@ class BibleManager(object):
|
|||||||
for bible in self.db_cache:
|
for bible in self.db_cache:
|
||||||
self.db_cache[bible].finalise()
|
self.db_cache[bible].finalise()
|
||||||
|
|
||||||
|
def _get_main_window(self):
|
||||||
|
"""
|
||||||
|
Adds the main window to the class dynamically
|
||||||
|
"""
|
||||||
|
if not hasattr(self, u'_main_window'):
|
||||||
|
self._main_window = Registry().get(u'main_window')
|
||||||
|
return self._main_window
|
||||||
|
|
||||||
|
main_window = property(_get_main_window)
|
||||||
|
|
||||||
BibleFormat.set_availability(BibleFormat.OpenLP1, HAS_OPENLP1)
|
BibleFormat.set_availability(BibleFormat.OpenLP1, HAS_OPENLP1)
|
||||||
|
|
||||||
__all__ = [u'BibleFormat']
|
__all__ = [u'BibleFormat']
|
||||||
|
@ -31,7 +31,7 @@ import logging
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import MediaManagerItem, Receiver, ItemCapabilities, ServiceItemContext, Settings, UiStrings, \
|
from openlp.core.lib import Registry, MediaManagerItem, ItemCapabilities, ServiceItemContext, Settings, UiStrings, \
|
||||||
create_separated_list, translate
|
create_separated_list, translate
|
||||||
from openlp.core.lib.searchedit import SearchEdit
|
from openlp.core.lib.searchedit import SearchEdit
|
||||||
from openlp.core.lib.ui import set_case_insensitive_completer, create_horizontal_adjusting_combo_box, \
|
from openlp.core.lib.ui import set_case_insensitive_completer, create_horizontal_adjusting_combo_box, \
|
||||||
@ -70,7 +70,8 @@ class BibleMediaItem(MediaManagerItem):
|
|||||||
self.search_results = {}
|
self.search_results = {}
|
||||||
self.second_search_results = {}
|
self.second_search_results = {}
|
||||||
self.checkSearchResult()
|
self.checkSearchResult()
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'bibles_load_list'), self.reloadBibles)
|
Registry().register_function(u'bibles_load_list', self.reload_bibles)
|
||||||
|
Registry().register_function(u'config_updated', self.config_update)
|
||||||
|
|
||||||
def __checkSecondBible(self, bible, second_bible):
|
def __checkSecondBible(self, bible, second_bible):
|
||||||
"""
|
"""
|
||||||
@ -246,7 +247,6 @@ class BibleMediaItem(MediaManagerItem):
|
|||||||
# Buttons
|
# Buttons
|
||||||
QtCore.QObject.connect(self.advancedSearchButton, QtCore.SIGNAL(u'clicked()'), self.onAdvancedSearchButton)
|
QtCore.QObject.connect(self.advancedSearchButton, QtCore.SIGNAL(u'clicked()'), self.onAdvancedSearchButton)
|
||||||
QtCore.QObject.connect(self.quickSearchButton, QtCore.SIGNAL(u'clicked()'), self.onQuickSearchButton)
|
QtCore.QObject.connect(self.quickSearchButton, QtCore.SIGNAL(u'clicked()'), self.onQuickSearchButton)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'config_updated'), self.configUpdated)
|
|
||||||
# Other stuff
|
# Other stuff
|
||||||
QtCore.QObject.connect(self.quickSearchEdit, QtCore.SIGNAL(u'returnPressed()'), self.onQuickSearchButton)
|
QtCore.QObject.connect(self.quickSearchEdit, QtCore.SIGNAL(u'returnPressed()'), self.onQuickSearchButton)
|
||||||
QtCore.QObject.connect(self.searchTabBar, QtCore.SIGNAL(u'currentChanged(int)'),
|
QtCore.QObject.connect(self.searchTabBar, QtCore.SIGNAL(u'currentChanged(int)'),
|
||||||
@ -258,8 +258,8 @@ class BibleMediaItem(MediaManagerItem):
|
|||||||
else:
|
else:
|
||||||
self.advancedBookComboBox.setFocus()
|
self.advancedBookComboBox.setFocus()
|
||||||
|
|
||||||
def configUpdated(self):
|
def config_update(self):
|
||||||
log.debug(u'configUpdated')
|
log.debug(u'config_update')
|
||||||
if Settings().value(self.settingsSection + u'/second bibles'):
|
if Settings().value(self.settingsSection + u'/second bibles'):
|
||||||
self.advancedSecondLabel.setVisible(True)
|
self.advancedSecondLabel.setVisible(True)
|
||||||
self.advancedSecondComboBox.setVisible(True)
|
self.advancedSecondComboBox.setVisible(True)
|
||||||
@ -313,7 +313,7 @@ class BibleMediaItem(MediaManagerItem):
|
|||||||
translate('BiblesPlugin.MediaItem', 'Search Text...'))
|
translate('BiblesPlugin.MediaItem', 'Search Text...'))
|
||||||
])
|
])
|
||||||
self.quickSearchEdit.setCurrentSearchType(Settings().value(u'%s/last search type' % self.settingsSection))
|
self.quickSearchEdit.setCurrentSearchType(Settings().value(u'%s/last search type' % self.settingsSection))
|
||||||
self.configUpdated()
|
self.config_update()
|
||||||
log.debug(u'bible manager initialise complete')
|
log.debug(u'bible manager initialise complete')
|
||||||
|
|
||||||
def loadBibles(self):
|
def loadBibles(self):
|
||||||
@ -343,7 +343,7 @@ class BibleMediaItem(MediaManagerItem):
|
|||||||
bible = Settings().value(self.settingsSection + u'/quick bible')
|
bible = Settings().value(self.settingsSection + u'/quick bible')
|
||||||
find_and_set_in_combo_box(self.quickVersionComboBox, bible)
|
find_and_set_in_combo_box(self.quickVersionComboBox, bible)
|
||||||
|
|
||||||
def reloadBibles(self, process=False):
|
def reload_bibles(self, process=False):
|
||||||
log.debug(u'Reloading Bibles')
|
log.debug(u'Reloading Bibles')
|
||||||
self.plugin.manager.reload_bibles()
|
self.plugin.manager.reload_bibles()
|
||||||
self.loadBibles()
|
self.loadBibles()
|
||||||
@ -471,7 +471,7 @@ class BibleMediaItem(MediaManagerItem):
|
|||||||
self.import_wizard = BibleImportForm(self, self.plugin.manager, self.plugin)
|
self.import_wizard = BibleImportForm(self, self.plugin.manager, self.plugin)
|
||||||
# If the import was not cancelled then reload.
|
# If the import was not cancelled then reload.
|
||||||
if self.import_wizard.exec_():
|
if self.import_wizard.exec_():
|
||||||
self.reloadBibles()
|
self.reload_bibles()
|
||||||
|
|
||||||
def onEditClick(self):
|
def onEditClick(self):
|
||||||
if self.quickTab.isVisible():
|
if self.quickTab.isVisible():
|
||||||
@ -482,7 +482,7 @@ class BibleMediaItem(MediaManagerItem):
|
|||||||
self.editBibleForm = EditBibleForm(self, self.main_window, self.plugin.manager)
|
self.editBibleForm = EditBibleForm(self, self.main_window, self.plugin.manager)
|
||||||
self.editBibleForm.loadBible(bible)
|
self.editBibleForm.loadBible(bible)
|
||||||
if self.editBibleForm.exec_():
|
if self.editBibleForm.exec_():
|
||||||
self.reloadBibles()
|
self.reload_bibles()
|
||||||
|
|
||||||
def onDeleteClick(self):
|
def onDeleteClick(self):
|
||||||
if self.quickTab.isVisible():
|
if self.quickTab.isVisible():
|
||||||
@ -497,7 +497,7 @@ class BibleMediaItem(MediaManagerItem):
|
|||||||
QtGui.QMessageBox.Yes) == QtGui.QMessageBox.No:
|
QtGui.QMessageBox.Yes) == QtGui.QMessageBox.No:
|
||||||
return
|
return
|
||||||
self.plugin.manager.delete_bible(bible)
|
self.plugin.manager.delete_bible(bible)
|
||||||
self.reloadBibles()
|
self.reload_bibles()
|
||||||
|
|
||||||
def onSearchTabBarCurrentChanged(self, index):
|
def onSearchTabBarCurrentChanged(self, index):
|
||||||
if index == 0:
|
if index == 0:
|
||||||
|
@ -31,9 +31,8 @@ import logging
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, translate
|
from openlp.core.lib import Registry, translate
|
||||||
from openlp.core.lib.ui import critical_error_message_box, \
|
from openlp.core.lib.ui import critical_error_message_box, find_and_set_in_combo_box
|
||||||
find_and_set_in_combo_box
|
|
||||||
from openlp.plugins.custom.lib import CustomXMLBuilder, CustomXMLParser
|
from openlp.plugins.custom.lib import CustomXMLBuilder, CustomXMLParser
|
||||||
from openlp.plugins.custom.lib.db import CustomSlide
|
from openlp.plugins.custom.lib.db import CustomSlide
|
||||||
from editcustomdialog import Ui_CustomEditDialog
|
from editcustomdialog import Ui_CustomEditDialog
|
||||||
@ -65,9 +64,9 @@ class EditCustomForm(QtGui.QDialog, Ui_CustomEditDialog):
|
|||||||
self.editAllButton.clicked.connect(self.on_edit_all_button_clicked)
|
self.editAllButton.clicked.connect(self.on_edit_all_button_clicked)
|
||||||
self.slideListView.currentRowChanged.connect(self.on_current_row_changed)
|
self.slideListView.currentRowChanged.connect(self.on_current_row_changed)
|
||||||
self.slideListView.doubleClicked.connect(self.on_edit_button_clicked)
|
self.slideListView.doubleClicked.connect(self.on_edit_button_clicked)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'theme_update_list'), self.loadThemes)
|
Registry().register_function(u'theme_update_list', self.load_themes)
|
||||||
|
|
||||||
def loadThemes(self, theme_list):
|
def load_themes(self, theme_list):
|
||||||
"""
|
"""
|
||||||
Load a list of themes into the themes combo box.
|
Load a list of themes into the themes combo box.
|
||||||
|
|
||||||
@ -191,7 +190,7 @@ class EditCustomForm(QtGui.QDialog, Ui_CustomEditDialog):
|
|||||||
"""
|
"""
|
||||||
log.debug(u'onPreview')
|
log.debug(u'onPreview')
|
||||||
if self.saveCustom():
|
if self.saveCustom():
|
||||||
Receiver.send_message(u'custom_preview')
|
Registry().execute(u'custom_preview')
|
||||||
|
|
||||||
def updateSlideList(self, slides, edit_all=False):
|
def updateSlideList(self, slides, edit_all=False):
|
||||||
"""
|
"""
|
||||||
|
@ -32,7 +32,7 @@ import logging
|
|||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
from sqlalchemy.sql import or_, func, and_
|
from sqlalchemy.sql import or_, func, and_
|
||||||
|
|
||||||
from openlp.core.lib import MediaManagerItem, Receiver, ItemCapabilities, ServiceItemContext, Settings, PluginStatus, \
|
from openlp.core.lib import Registry, MediaManagerItem, ItemCapabilities, ServiceItemContext, Settings, PluginStatus,\
|
||||||
UiStrings, check_item_selected, translate
|
UiStrings, check_item_selected, translate
|
||||||
from openlp.plugins.custom.forms import EditCustomForm
|
from openlp.plugins.custom.forms import EditCustomForm
|
||||||
from openlp.plugins.custom.lib import CustomXMLParser, CustomXMLBuilder
|
from openlp.plugins.custom.lib import CustomXMLParser, CustomXMLBuilder
|
||||||
@ -73,11 +73,10 @@ class CustomMediaItem(MediaManagerItem):
|
|||||||
QtCore.QObject.connect(self.searchTextEdit, QtCore.SIGNAL(u'cleared()'), self.onClearTextButtonClick)
|
QtCore.QObject.connect(self.searchTextEdit, QtCore.SIGNAL(u'cleared()'), self.onClearTextButtonClick)
|
||||||
QtCore.QObject.connect(self.searchTextEdit, QtCore.SIGNAL(u'searchTypeChanged(int)'),
|
QtCore.QObject.connect(self.searchTextEdit, QtCore.SIGNAL(u'searchTypeChanged(int)'),
|
||||||
self.onSearchTextButtonClicked)
|
self.onSearchTextButtonClicked)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'custom_load_list'), self.loadList)
|
Registry().register_function(u'custom_load_list', self.loadList)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'custom_preview'), self.onPreviewClick)
|
Registry().register_function(u'custom_preview', self.onPreviewClick)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'config_updated'), self.config_updated)
|
Registry().register_function(u'config_updated', self.config_updated)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'custom_create_from_service'),
|
Registry().register_function(u'custom_create_from_service', self.create_from_service_item)
|
||||||
self.create_from_service_item)
|
|
||||||
|
|
||||||
def config_updated(self):
|
def config_updated(self):
|
||||||
self.add_custom_from_service = Settings().value(self.settingsSection + u'/add custom from service')
|
self.add_custom_from_service = Settings().value(self.settingsSection + u'/add custom from service')
|
||||||
@ -280,7 +279,7 @@ class CustomMediaItem(MediaManagerItem):
|
|||||||
self.plugin.manager.save_object(custom)
|
self.plugin.manager.save_object(custom)
|
||||||
self.onSearchTextButtonClicked()
|
self.onSearchTextButtonClicked()
|
||||||
if item.name.lower() == u'custom':
|
if item.name.lower() == u'custom':
|
||||||
Receiver.send_message(u'service_item_update', u'%s:%s:%s' % (custom.id, item.unique_identifier, False))
|
Registry().execute(u'service_item_update', u'%s:%s:%s' % (custom.id, item.unique_identifier, False))
|
||||||
|
|
||||||
def onClearTextButtonClick(self):
|
def onClearTextButtonClick(self):
|
||||||
"""
|
"""
|
||||||
|
@ -31,7 +31,7 @@ from PyQt4 import QtCore, QtGui
|
|||||||
|
|
||||||
import logging
|
import logging
|
||||||
|
|
||||||
from openlp.core.lib import Plugin, StringContent, Receiver, ImageSource, Settings, build_icon, translate
|
from openlp.core.lib import Plugin, StringContent, Registry, ImageSource, Settings, build_icon, translate
|
||||||
from openlp.plugins.images.lib import ImageMediaItem, ImageTab
|
from openlp.plugins.images.lib import ImageMediaItem, ImageTab
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
@ -50,7 +50,7 @@ class ImagePlugin(Plugin):
|
|||||||
self.weight = -7
|
self.weight = -7
|
||||||
self.iconPath = u':/plugins/plugin_images.png'
|
self.iconPath = u':/plugins/plugin_images.png'
|
||||||
self.icon = build_icon(self.iconPath)
|
self.icon = build_icon(self.iconPath)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'image_updated'), self.image_updated)
|
Registry().execute(u'image_updated', self.image_updated)
|
||||||
|
|
||||||
def about(self):
|
def about(self):
|
||||||
about_text = translate('ImagePlugin', '<strong>Image Plugin</strong>'
|
about_text = translate('ImagePlugin', '<strong>Image Plugin</strong>'
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import SettingsTab, Receiver, Settings, UiStrings, translate
|
from openlp.core.lib import SettingsTab, Registry, Settings, UiStrings, translate
|
||||||
|
|
||||||
class ImageTab(SettingsTab):
|
class ImageTab(SettingsTab):
|
||||||
"""
|
"""
|
||||||
@ -91,5 +91,5 @@ class ImageTab(SettingsTab):
|
|||||||
settings.setValue(u'background color', self.bg_color)
|
settings.setValue(u'background color', self.bg_color)
|
||||||
settings.endGroup()
|
settings.endGroup()
|
||||||
if self.initial_color != self.bg_color:
|
if self.initial_color != self.bg_color:
|
||||||
Receiver.send_message(u'image_updated')
|
Registry().execute(u'image_updated')
|
||||||
|
|
||||||
|
@ -32,7 +32,7 @@ import os
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import MediaManagerItem, ItemCapabilities, Receiver, SettingsManager, ServiceItemContext, \
|
from openlp.core.lib import MediaManagerItem, ItemCapabilities, Registry, SettingsManager, ServiceItemContext, \
|
||||||
Settings, UiStrings, build_icon, check_item_selected, check_directory_exists, create_thumb, translate, \
|
Settings, UiStrings, build_icon, check_item_selected, check_directory_exists, create_thumb, translate, \
|
||||||
validate_thumb
|
validate_thumb
|
||||||
from openlp.core.lib.ui import critical_error_message_box
|
from openlp.core.lib.ui import critical_error_message_box
|
||||||
@ -51,7 +51,7 @@ class ImageMediaItem(MediaManagerItem):
|
|||||||
MediaManagerItem.__init__(self, parent, plugin, icon)
|
MediaManagerItem.__init__(self, parent, plugin, icon)
|
||||||
self.quickPreviewAllowed = True
|
self.quickPreviewAllowed = True
|
||||||
self.hasSearch = True
|
self.hasSearch = True
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'live_theme_changed'), self.liveThemeChanged)
|
Registry().register_function(u'live_theme_changed', self.live_theme_changed)
|
||||||
# Allow DnD from the desktop
|
# Allow DnD from the desktop
|
||||||
self.listView.activateDnD()
|
self.listView.activateDnD()
|
||||||
|
|
||||||
@ -194,7 +194,7 @@ class ImageMediaItem(MediaManagerItem):
|
|||||||
self.resetAction.setVisible(False)
|
self.resetAction.setVisible(False)
|
||||||
self.live_controller.display.resetImage()
|
self.live_controller.display.resetImage()
|
||||||
|
|
||||||
def liveThemeChanged(self):
|
def live_theme_changed(self):
|
||||||
"""
|
"""
|
||||||
Triggered by the change of theme in the slide controller
|
Triggered by the change of theme in the slide controller
|
||||||
"""
|
"""
|
||||||
|
@ -32,7 +32,7 @@ import os
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import ItemCapabilities, MediaManagerItem,MediaType, Receiver, ServiceItem, ServiceItemContext, \
|
from openlp.core.lib import ItemCapabilities, MediaManagerItem,MediaType, Registry, ServiceItem, ServiceItemContext, \
|
||||||
Settings, UiStrings, build_icon, check_item_selected, check_directory_exists, translate
|
Settings, UiStrings, build_icon, check_item_selected, check_directory_exists, translate
|
||||||
from openlp.core.lib.ui import critical_error_message_box, create_horizontal_adjusting_combo_box
|
from openlp.core.lib.ui import critical_error_message_box, create_horizontal_adjusting_combo_box
|
||||||
from openlp.core.ui import DisplayController, Display, DisplayControllerType
|
from openlp.core.ui import DisplayController, Display, DisplayControllerType
|
||||||
@ -71,10 +71,9 @@ class MediaMediaItem(MediaManagerItem):
|
|||||||
self.displayController.previewDisplay.screen = {u'size':self.displayController.previewDisplay.geometry()}
|
self.displayController.previewDisplay.screen = {u'size':self.displayController.previewDisplay.geometry()}
|
||||||
self.displayController.previewDisplay.setup()
|
self.displayController.previewDisplay.setup()
|
||||||
self.media_controller.setup_display(self.displayController.previewDisplay, False)
|
self.media_controller.setup_display(self.displayController.previewDisplay, False)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'video_background_replaced'),
|
Registry().register_function(u'video_background_replaced', self.video_background_replaced)
|
||||||
self.videobackgroundReplaced)
|
Registry().register_function(u'mediaitem_media_rebuild', self.rebuild_players)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'mediaitem_media_rebuild'), self.rebuild_players)
|
Registry().register_function(u'config_screen_changed', self.display_setup)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'config_screen_changed'), self.displaySetup)
|
|
||||||
# Allow DnD from the desktop
|
# Allow DnD from the desktop
|
||||||
self.listView.activateDnD()
|
self.listView.activateDnD()
|
||||||
|
|
||||||
@ -133,7 +132,7 @@ class MediaMediaItem(MediaManagerItem):
|
|||||||
self.media_controller.media_reset(self.live_controller)
|
self.media_controller.media_reset(self.live_controller)
|
||||||
self.resetAction.setVisible(False)
|
self.resetAction.setVisible(False)
|
||||||
|
|
||||||
def videobackgroundReplaced(self):
|
def video_background_replaced(self):
|
||||||
"""
|
"""
|
||||||
Triggered by main display on change of serviceitem.
|
Triggered by main display on change of serviceitem.
|
||||||
"""
|
"""
|
||||||
@ -214,7 +213,7 @@ class MediaMediaItem(MediaManagerItem):
|
|||||||
u' '.join(self.media_controller.video_extensions_list),
|
u' '.join(self.media_controller.video_extensions_list),
|
||||||
u' '.join(self.media_controller.audio_extensions_list), UiStrings().AllFiles)
|
u' '.join(self.media_controller.audio_extensions_list), UiStrings().AllFiles)
|
||||||
|
|
||||||
def displaySetup(self):
|
def display_setup(self):
|
||||||
self.media_controller.setup_display(self.displayController.previewDisplay, False)
|
self.media_controller.setup_display(self.displayController.previewDisplay, False)
|
||||||
|
|
||||||
def populateDisplayTypes(self):
|
def populateDisplayTypes(self):
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
|
|
||||||
from PyQt4 import QtGui
|
from PyQt4 import QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, Settings, SettingsTab, UiStrings, translate
|
from openlp.core.lib import Registry, Settings, SettingsTab, UiStrings, translate
|
||||||
|
|
||||||
class MediaQCheckBox(QtGui.QCheckBox):
|
class MediaQCheckBox(QtGui.QCheckBox):
|
||||||
"""
|
"""
|
||||||
@ -84,5 +84,5 @@ class MediaTab(SettingsTab):
|
|||||||
Settings().setValue(setting_key, self.autoStartCheckBox.checkState())
|
Settings().setValue(setting_key, self.autoStartCheckBox.checkState())
|
||||||
if override_changed:
|
if override_changed:
|
||||||
self.parent.reset_supported_suffixes()
|
self.parent.reset_supported_suffixes()
|
||||||
Receiver.send_message(u'mediaitem_media_rebuild')
|
Registry().execute(u'mediaitem_media_rebuild')
|
||||||
Receiver.send_message(u'mediaitem_suffixes')
|
Registry().execute(u'mediaitem_suffixes')
|
||||||
|
@ -32,7 +32,7 @@ import os
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import MediaManagerItem, Receiver, ItemCapabilities, ServiceItemContext, Settings, UiStrings, \
|
from openlp.core.lib import MediaManagerItem, Registry, ItemCapabilities, ServiceItemContext, Settings, UiStrings, \
|
||||||
build_icon, check_item_selected, create_thumb, translate, validate_thumb
|
build_icon, check_item_selected, create_thumb, translate, validate_thumb
|
||||||
from openlp.core.lib.ui import critical_error_message_box, create_horizontal_adjusting_combo_box
|
from openlp.core.lib.ui import critical_error_message_box, create_horizontal_adjusting_combo_box
|
||||||
from openlp.core.utils import locale_compare
|
from openlp.core.utils import locale_compare
|
||||||
@ -60,9 +60,8 @@ class PresentationMediaItem(MediaManagerItem):
|
|||||||
self.message_listener = MessageListener(self)
|
self.message_listener = MessageListener(self)
|
||||||
self.hasSearch = True
|
self.hasSearch = True
|
||||||
self.singleServiceItem = False
|
self.singleServiceItem = False
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'mediaitem_presentation_rebuild'),
|
Registry().register_function(u'mediaitem_presentation_rebuild', self.populate_display_types)
|
||||||
self.populateDisplayTypes)
|
Registry().register_function(u'mediaitem_suffixes', self.build_file_mask_string)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'mediaitem_suffixes'), self.buildFileMaskString)
|
|
||||||
# Allow DnD from the desktop
|
# Allow DnD from the desktop
|
||||||
self.listView.activateDnD()
|
self.listView.activateDnD()
|
||||||
|
|
||||||
@ -74,7 +73,7 @@ class PresentationMediaItem(MediaManagerItem):
|
|||||||
self.Automatic = translate('PresentationPlugin.MediaItem', 'Automatic')
|
self.Automatic = translate('PresentationPlugin.MediaItem', 'Automatic')
|
||||||
self.displayTypeLabel.setText(translate('PresentationPlugin.MediaItem', 'Present using:'))
|
self.displayTypeLabel.setText(translate('PresentationPlugin.MediaItem', 'Present using:'))
|
||||||
|
|
||||||
def buildFileMaskString(self):
|
def build_file_mask_string(self):
|
||||||
"""
|
"""
|
||||||
Build the list of file extensions to be used in the Open file dialog
|
Build the list of file extensions to be used in the Open file dialog
|
||||||
"""
|
"""
|
||||||
@ -122,9 +121,9 @@ class PresentationMediaItem(MediaManagerItem):
|
|||||||
self.listView.setIconSize(QtCore.QSize(88, 50))
|
self.listView.setIconSize(QtCore.QSize(88, 50))
|
||||||
files = Settings().value(self.settingsSection + u'/presentations files')
|
files = Settings().value(self.settingsSection + u'/presentations files')
|
||||||
self.loadList(files, True)
|
self.loadList(files, True)
|
||||||
self.populateDisplayTypes()
|
self.populate_display_types()
|
||||||
|
|
||||||
def populateDisplayTypes(self):
|
def populate_display_types(self):
|
||||||
"""
|
"""
|
||||||
Load the combobox with the enabled presentation controllers,
|
Load the combobox with the enabled presentation controllers,
|
||||||
allowing user to select a specific app if settings allow
|
allowing user to select a specific app if settings allow
|
||||||
|
@ -31,7 +31,7 @@ import logging
|
|||||||
|
|
||||||
from PyQt4 import QtCore
|
from PyQt4 import QtCore
|
||||||
|
|
||||||
from openlp.core.lib import Receiver
|
from openlp.core.lib import Registry
|
||||||
from openlp.core.ui import HideMode
|
from openlp.core.ui import HideMode
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
@ -71,7 +71,7 @@ class Controller(object):
|
|||||||
self.hide_mode = hide_mode
|
self.hide_mode = hide_mode
|
||||||
if self.is_live:
|
if self.is_live:
|
||||||
if hide_mode == HideMode.Screen:
|
if hide_mode == HideMode.Screen:
|
||||||
Receiver.send_message(u'live_display_hide', HideMode.Screen)
|
Registry().execute(u'live_display_hide', HideMode.Screen)
|
||||||
self.stop()
|
self.stop()
|
||||||
elif hide_mode == HideMode.Theme:
|
elif hide_mode == HideMode.Theme:
|
||||||
self.blank(hide_mode)
|
self.blank(hide_mode)
|
||||||
@ -79,7 +79,7 @@ class Controller(object):
|
|||||||
self.blank(hide_mode)
|
self.blank(hide_mode)
|
||||||
else:
|
else:
|
||||||
self.doc.start_presentation()
|
self.doc.start_presentation()
|
||||||
Receiver.send_message(u'live_display_hide', HideMode.Screen)
|
Registry().execute(u'live_display_hide', HideMode.Screen)
|
||||||
self.doc.slidenumber = 1
|
self.doc.slidenumber = 1
|
||||||
if slide_no > 1:
|
if slide_no > 1:
|
||||||
self.slide(slide_no)
|
self.slide(slide_no)
|
||||||
@ -236,7 +236,7 @@ class Controller(object):
|
|||||||
return
|
return
|
||||||
if not self.doc.is_active():
|
if not self.doc.is_active():
|
||||||
return
|
return
|
||||||
Receiver.send_message(u'live_display_hide', HideMode.Theme)
|
Registry().execute(u'live_display_hide', HideMode.Theme)
|
||||||
elif hide_mode == HideMode.Blank:
|
elif hide_mode == HideMode.Blank:
|
||||||
if not self.activate():
|
if not self.activate():
|
||||||
return
|
return
|
||||||
@ -273,7 +273,7 @@ class Controller(object):
|
|||||||
if self.doc.slidenumber and self.doc.slidenumber != self.doc.get_slide_number():
|
if self.doc.slidenumber and self.doc.slidenumber != self.doc.get_slide_number():
|
||||||
self.doc.goto_slide(self.doc.slidenumber)
|
self.doc.goto_slide(self.doc.slidenumber)
|
||||||
self.doc.unblank_screen()
|
self.doc.unblank_screen()
|
||||||
Receiver.send_message(u'live_display_hide', HideMode.Screen)
|
Registry().execute(u'live_display_hide', HideMode.Screen)
|
||||||
|
|
||||||
def poll(self):
|
def poll(self):
|
||||||
if not self.doc:
|
if not self.doc:
|
||||||
@ -294,16 +294,16 @@ class MessageListener(object):
|
|||||||
self.preview_handler = Controller(False)
|
self.preview_handler = Controller(False)
|
||||||
self.live_handler = Controller(True)
|
self.live_handler = Controller(True)
|
||||||
# messages are sent from core.ui.slidecontroller
|
# messages are sent from core.ui.slidecontroller
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'presentations_start'), self.startup)
|
Registry().register_function(u'presentations_start', self.startup)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'presentations_stop'), self.shutdown)
|
Registry().register_function(u'presentations_stop', self.shutdown)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'presentations_hide'), self.hide)
|
Registry().register_function(u'presentations_hide', self.hide)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'presentations_first'), self.first)
|
Registry().register_function(u'presentations_first', self.first)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'presentations_previous'), self.previous)
|
Registry().register_function(u'presentations_previous', self.previous)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'presentations_next'), self.next)
|
Registry().register_function(u'presentations_next', self.next)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'presentations_last'), self.last)
|
Registry().register_function(u'presentations_last', self.last)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'presentations_slide'), self.slide)
|
Registry().register_function(u'presentations_slide', self.slide)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'presentations_blank'), self.blank)
|
Registry().register_function(u'presentations_blank', self.blank)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'presentations_unblank'), self.unblank)
|
Registry().register_function(u'presentations_unblank', self.unblank)
|
||||||
self.timer = QtCore.QTimer()
|
self.timer = QtCore.QTimer()
|
||||||
self.timer.setInterval(500)
|
self.timer.setInterval(500)
|
||||||
QtCore.QObject.connect(self.timer, QtCore.SIGNAL(u'timeout()'), self.timeout)
|
QtCore.QObject.connect(self.timer, QtCore.SIGNAL(u'timeout()'), self.timeout)
|
||||||
|
@ -33,7 +33,7 @@ import shutil
|
|||||||
|
|
||||||
from PyQt4 import QtCore
|
from PyQt4 import QtCore
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, Registry, Settings, check_directory_exists, create_thumb, validate_thumb
|
from openlp.core.lib import Registry, Settings, check_directory_exists, create_thumb, validate_thumb
|
||||||
from openlp.core.utils import AppLocation
|
from openlp.core.utils import AppLocation
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
@ -274,7 +274,7 @@ class PresentationDocument(object):
|
|||||||
prefix = u'live'
|
prefix = u'live'
|
||||||
else:
|
else:
|
||||||
prefix = u'preview'
|
prefix = u'preview'
|
||||||
Receiver.send_message(u'slidecontroller_%s_change' % prefix, self.slidenumber - 1)
|
Registry().execute(u'slidecontroller_%s_change' % prefix, self.slidenumber - 1)
|
||||||
|
|
||||||
def get_slide_text(self, slide_no):
|
def get_slide_text(self, slide_no):
|
||||||
"""
|
"""
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
|
|
||||||
from PyQt4 import QtGui
|
from PyQt4 import QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, Settings, SettingsTab, UiStrings, translate
|
from openlp.core.lib import Registry, Settings, SettingsTab, UiStrings, translate
|
||||||
|
|
||||||
class PresentationTab(SettingsTab):
|
class PresentationTab(SettingsTab):
|
||||||
"""
|
"""
|
||||||
@ -130,8 +130,8 @@ class PresentationTab(SettingsTab):
|
|||||||
changed = True
|
changed = True
|
||||||
if changed:
|
if changed:
|
||||||
self.parent.reset_supported_suffixes()
|
self.parent.reset_supported_suffixes()
|
||||||
Receiver.send_message(u'mediaitem_presentation_rebuild')
|
Registry().execute(u'mediaitem_presentation_rebuild')
|
||||||
Receiver.send_message(u'mediaitem_suffixes')
|
Registry().execute(u'mediaitem_suffixes')
|
||||||
|
|
||||||
def tabVisible(self):
|
def tabVisible(self):
|
||||||
"""
|
"""
|
||||||
|
@ -37,8 +37,7 @@ from PyQt4 import QtCore
|
|||||||
|
|
||||||
from openlp.core.lib import Plugin, StringContent, build_icon, translate
|
from openlp.core.lib import Plugin, StringContent, build_icon, translate
|
||||||
from openlp.core.utils import AppLocation
|
from openlp.core.utils import AppLocation
|
||||||
from openlp.plugins.presentations.lib import PresentationController, \
|
from openlp.plugins.presentations.lib import PresentationController, PresentationMediaItem, PresentationTab
|
||||||
PresentationMediaItem, PresentationTab
|
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
@ -91,7 +90,7 @@ class PresentationPlugin(Plugin):
|
|||||||
except Exception:
|
except Exception:
|
||||||
log.warn(u'Failed to start controller process')
|
log.warn(u'Failed to start controller process')
|
||||||
self.controllers[controller].available = False
|
self.controllers[controller].available = False
|
||||||
self.mediaItem.buildFileMaskString()
|
self.mediaItem.build_file_mask_string()
|
||||||
|
|
||||||
def finalise(self):
|
def finalise(self):
|
||||||
"""
|
"""
|
||||||
|
@ -123,7 +123,7 @@ import urlparse
|
|||||||
from PyQt4 import QtCore, QtNetwork
|
from PyQt4 import QtCore, QtNetwork
|
||||||
from mako.template import Template
|
from mako.template import Template
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, Settings, PluginStatus, StringContent
|
from openlp.core.lib import Registry, Settings, PluginStatus, StringContent
|
||||||
from openlp.core.utils import AppLocation, translate
|
from openlp.core.utils import AppLocation, translate
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
@ -175,10 +175,8 @@ class HttpServer(object):
|
|||||||
address = Settings().value(self.plugin.settingsSection + u'/ip address')
|
address = Settings().value(self.plugin.settingsSection + u'/ip address')
|
||||||
self.server = QtNetwork.QTcpServer()
|
self.server = QtNetwork.QTcpServer()
|
||||||
self.server.listen(QtNetwork.QHostAddress(address), port)
|
self.server.listen(QtNetwork.QHostAddress(address), port)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'slidecontroller_live_changed'),
|
Registry().register_function(u'slidecontroller_live_changed', self.slide_change)
|
||||||
self.slide_change)
|
Registry().register_function(u'slidecontroller_live_started', self.item_change)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'slidecontroller_live_started'),
|
|
||||||
self.item_change)
|
|
||||||
QtCore.QObject.connect(self.server, QtCore.SIGNAL(u'newConnection()'), self.new_connection)
|
QtCore.QObject.connect(self.server, QtCore.SIGNAL(u'newConnection()'), self.new_connection)
|
||||||
log.debug(u'TCP listening on port %d' % port)
|
log.debug(u'TCP listening on port %d' % port)
|
||||||
|
|
||||||
@ -406,7 +404,7 @@ class HttpConnection(object):
|
|||||||
``action``
|
``action``
|
||||||
This is the action, either ``hide`` or ``show``.
|
This is the action, either ``hide`` or ``show``.
|
||||||
"""
|
"""
|
||||||
Receiver.send_message(u'slidecontroller_toggle_display', action)
|
Registry().execute(u'slidecontroller_toggle_display', action)
|
||||||
return HttpResponse(json.dumps({u'results': {u'success': True}}),
|
return HttpResponse(json.dumps({u'results': {u'success': True}}),
|
||||||
{u'Content-Type': u'application/json'})
|
{u'Content-Type': u'application/json'})
|
||||||
|
|
||||||
@ -421,7 +419,7 @@ class HttpConnection(object):
|
|||||||
except KeyError, ValueError:
|
except KeyError, ValueError:
|
||||||
return HttpResponse(code=u'400 Bad Request')
|
return HttpResponse(code=u'400 Bad Request')
|
||||||
text = urllib.unquote(text)
|
text = urllib.unquote(text)
|
||||||
Receiver.send_message(u'alerts_text', [text])
|
Registry().execute(u'alerts_text', [text])
|
||||||
success = True
|
success = True
|
||||||
else:
|
else:
|
||||||
success = False
|
success = False
|
||||||
@ -471,9 +469,9 @@ class HttpConnection(object):
|
|||||||
log.info(data)
|
log.info(data)
|
||||||
# This slot expects an int within a list.
|
# This slot expects an int within a list.
|
||||||
id = data[u'request'][u'id']
|
id = data[u'request'][u'id']
|
||||||
Receiver.send_message(event, [id])
|
Registry().execute(event, [id])
|
||||||
else:
|
else:
|
||||||
Receiver.send_message(event)
|
Registry().execute(event)
|
||||||
json_data = {u'results': {u'success': True}}
|
json_data = {u'results': {u'success': True}}
|
||||||
return HttpResponse(json.dumps(json_data),
|
return HttpResponse(json.dumps(json_data),
|
||||||
{u'Content-Type': u'application/json'})
|
{u'Content-Type': u'application/json'})
|
||||||
@ -490,9 +488,9 @@ class HttpConnection(object):
|
|||||||
data = json.loads(self.url_params[u'data'][0])
|
data = json.loads(self.url_params[u'data'][0])
|
||||||
except KeyError, ValueError:
|
except KeyError, ValueError:
|
||||||
return HttpResponse(code=u'400 Bad Request')
|
return HttpResponse(code=u'400 Bad Request')
|
||||||
Receiver.send_message(event, data[u'request'][u'id'])
|
Registry().execute(event, data[u'request'][u'id'])
|
||||||
else:
|
else:
|
||||||
Receiver.send_message(event)
|
Registry().execute(event)
|
||||||
return HttpResponse(json.dumps({u'results': {u'success': True}}),
|
return HttpResponse(json.dumps({u'results': {u'success': True}}),
|
||||||
{u'Content-Type': u'application/json'})
|
{u'Content-Type': u'application/json'})
|
||||||
|
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui, QtNetwork
|
from PyQt4 import QtCore, QtGui, QtNetwork
|
||||||
|
|
||||||
from openlp.core.lib import Settings, SettingsTab, Receiver, translate
|
from openlp.core.lib import Registry, Settings, SettingsTab, translate
|
||||||
|
|
||||||
|
|
||||||
ZERO_URL = u'0.0.0.0'
|
ZERO_URL = u'0.0.0.0'
|
||||||
@ -152,7 +152,7 @@ class RemoteTab(SettingsTab):
|
|||||||
Settings().setValue(self.settingsSection + u'/ip address', self.addressEdit.text())
|
Settings().setValue(self.settingsSection + u'/ip address', self.addressEdit.text())
|
||||||
Settings().setValue(self.settingsSection + u'/twelve hour', self.twelveHour)
|
Settings().setValue(self.settingsSection + u'/twelve hour', self.twelveHour)
|
||||||
if changed:
|
if changed:
|
||||||
Receiver.send_message(u'remotes_config_updated')
|
Registry().register_function(u'remotes_config_updated')
|
||||||
|
|
||||||
def onTwelveHourCheckBoxChanged(self, check_state):
|
def onTwelveHourCheckBoxChanged(self, check_state):
|
||||||
self.twelveHour = False
|
self.twelveHour = False
|
||||||
|
@ -95,7 +95,7 @@ class RemotesPlugin(Plugin):
|
|||||||
u'title': translate('RemotePlugin', 'Remote', 'container title')
|
u'title': translate('RemotePlugin', 'Remote', 'container title')
|
||||||
}
|
}
|
||||||
|
|
||||||
def configUpdated(self):
|
def config_update(self):
|
||||||
"""
|
"""
|
||||||
Called when Config is changed to restart the server on new address or
|
Called when Config is changed to restart the server on new address or
|
||||||
port
|
port
|
||||||
|
@ -38,8 +38,8 @@ import shutil
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import PluginStatus, Receiver, MediaType, Registry, UiStrings, translate, create_separated_list, \
|
from openlp.core.lib import Registry, PluginStatus, MediaType, translate, create_separated_list, \
|
||||||
check_directory_exists
|
check_directory_exists, UiStrings
|
||||||
from openlp.core.lib.ui import set_case_insensitive_completer, critical_error_message_box, \
|
from openlp.core.lib.ui import set_case_insensitive_completer, critical_error_message_box, \
|
||||||
find_and_set_in_combo_box
|
find_and_set_in_combo_box
|
||||||
from openlp.core.utils import AppLocation
|
from openlp.core.utils import AppLocation
|
||||||
@ -97,7 +97,7 @@ class EditSongForm(QtGui.QDialog, Ui_EditSongDialog):
|
|||||||
QtCore.QObject.connect(self.audioRemoveButton, QtCore.SIGNAL(u'clicked()'), self.onAudioRemoveButtonClicked)
|
QtCore.QObject.connect(self.audioRemoveButton, QtCore.SIGNAL(u'clicked()'), self.onAudioRemoveButtonClicked)
|
||||||
QtCore.QObject.connect(self.audioRemoveAllButton, QtCore.SIGNAL(u'clicked()'),
|
QtCore.QObject.connect(self.audioRemoveAllButton, QtCore.SIGNAL(u'clicked()'),
|
||||||
self.onAudioRemoveAllButtonClicked)
|
self.onAudioRemoveAllButtonClicked)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'theme_update_list'), self.loadThemes)
|
Registry().register_function(u'theme_update_list', self.load_themes)
|
||||||
self.previewButton = QtGui.QPushButton()
|
self.previewButton = QtGui.QPushButton()
|
||||||
self.previewButton.setObjectName(u'previewButton')
|
self.previewButton.setObjectName(u'previewButton')
|
||||||
self.previewButton.setText(UiStrings().SaveAndPreview)
|
self.previewButton.setText(UiStrings().SaveAndPreview)
|
||||||
@ -169,7 +169,7 @@ class EditSongForm(QtGui.QDialog, Ui_EditSongDialog):
|
|||||||
combo.setItemData(row, object.id)
|
combo.setItemData(row, object.id)
|
||||||
set_case_insensitive_completer(cache, combo)
|
set_case_insensitive_completer(cache, combo)
|
||||||
|
|
||||||
def loadThemes(self, theme_list):
|
def load_themes(self, theme_list):
|
||||||
"""
|
"""
|
||||||
Load the themes into a combobox.
|
Load the themes into a combobox.
|
||||||
"""
|
"""
|
||||||
@ -699,7 +699,7 @@ class EditSongForm(QtGui.QDialog, Ui_EditSongDialog):
|
|||||||
log.debug(u'onPreview')
|
log.debug(u'onPreview')
|
||||||
if button.objectName() == u'previewButton':
|
if button.objectName() == u'previewButton':
|
||||||
self.saveSong(True)
|
self.saveSong(True)
|
||||||
Receiver.send_message(u'songs_preview')
|
Registry().execute(u'songs_preview')
|
||||||
|
|
||||||
def onAudioAddFromFileButtonClicked(self):
|
def onAudioAddFromFileButtonClicked(self):
|
||||||
"""
|
"""
|
||||||
|
@ -34,7 +34,7 @@ import logging
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, UiStrings, create_separated_list, build_icon, translate
|
from openlp.core.lib import Registry, UiStrings, create_separated_list, build_icon, translate
|
||||||
from openlp.core.lib.ui import critical_error_message_box
|
from openlp.core.lib.ui import critical_error_message_box
|
||||||
from openlp.core.ui.wizard import OpenLPWizard, WizardStrings
|
from openlp.core.ui.wizard import OpenLPWizard, WizardStrings
|
||||||
from openlp.plugins.songs.lib import natcmp
|
from openlp.plugins.songs.lib import natcmp
|
||||||
@ -62,7 +62,7 @@ class SongExportForm(OpenLPWizard):
|
|||||||
"""
|
"""
|
||||||
OpenLPWizard.__init__(self, parent, plugin, u'songExportWizard', u':/wizards/wizard_exportsong.bmp')
|
OpenLPWizard.__init__(self, parent, plugin, u'songExportWizard', u':/wizards/wizard_exportsong.bmp')
|
||||||
self.stop_export_flag = False
|
self.stop_export_flag = False
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'openlp_stop_wizard'), self.stop_export)
|
Registry().register_function(u'openlp_stop_wizard', self.stop_export)
|
||||||
|
|
||||||
def stop_export(self):
|
def stop_export(self):
|
||||||
"""
|
"""
|
||||||
|
@ -31,7 +31,7 @@ import logging
|
|||||||
from PyQt4 import QtGui, QtCore
|
from PyQt4 import QtGui, QtCore
|
||||||
from sqlalchemy.sql import and_
|
from sqlalchemy.sql import and_
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, UiStrings, translate
|
from openlp.core.lib import Registry, UiStrings, translate
|
||||||
from openlp.core.lib.ui import critical_error_message_box
|
from openlp.core.lib.ui import critical_error_message_box
|
||||||
from openlp.plugins.songs.forms import AuthorsForm, TopicsForm, SongBookForm
|
from openlp.plugins.songs.forms import AuthorsForm, TopicsForm, SongBookForm
|
||||||
from openlp.plugins.songs.lib.db import Author, Book, Topic, Song
|
from openlp.plugins.songs.lib.db import Author, Book, Topic, Song
|
||||||
@ -283,7 +283,7 @@ class SongMaintenanceForm(QtGui.QDialog, Ui_SongMaintenanceDialog):
|
|||||||
if self.manager.save_object(author):
|
if self.manager.save_object(author):
|
||||||
self.resetAuthors()
|
self.resetAuthors()
|
||||||
if not self.fromSongEdit:
|
if not self.fromSongEdit:
|
||||||
Receiver.send_message(u'songs_load_list')
|
Registry().execute(u'songs_load_list')
|
||||||
else:
|
else:
|
||||||
critical_error_message_box(
|
critical_error_message_box(
|
||||||
message=translate('SongsPlugin.SongMaintenanceForm', 'Could not save your changes.'))
|
message=translate('SongsPlugin.SongMaintenanceForm', 'Could not save your changes.'))
|
||||||
@ -378,7 +378,7 @@ class SongMaintenanceForm(QtGui.QDialog, Ui_SongMaintenanceDialog):
|
|||||||
merge(dbObject)
|
merge(dbObject)
|
||||||
reset()
|
reset()
|
||||||
if not self.fromSongEdit:
|
if not self.fromSongEdit:
|
||||||
Receiver.send_message(u'songs_load_list')
|
Registry().execute(u'songs_load_list')
|
||||||
self.application.set_normal_cursor()
|
self.application.set_normal_cursor()
|
||||||
|
|
||||||
def mergeAuthors(self, oldAuthor):
|
def mergeAuthors(self, oldAuthor):
|
||||||
|
@ -95,7 +95,7 @@ class CCLIFileImport(SongImport):
|
|||||||
self.logError(filename,
|
self.logError(filename,
|
||||||
translate('SongsPlugin.CCLIFileImport', 'The file does not have a valid extension.'))
|
translate('SongsPlugin.CCLIFileImport', 'The file does not have a valid extension.'))
|
||||||
log.info(u'Extension %s is not valid', filename)
|
log.info(u'Extension %s is not valid', filename)
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
return
|
return
|
||||||
|
|
||||||
def doImportUsrFile(self, textList):
|
def doImportUsrFile(self, textList):
|
||||||
|
@ -90,7 +90,7 @@ class DreamBeamImport(SongImport):
|
|||||||
if isinstance(self.importSource, list):
|
if isinstance(self.importSource, list):
|
||||||
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
||||||
for file in self.importSource:
|
for file in self.importSource:
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
return
|
return
|
||||||
self.setDefaults()
|
self.setDefaults()
|
||||||
parser = etree.XMLParser(remove_blank_text=True)
|
parser = etree.XMLParser(remove_blank_text=True)
|
||||||
|
@ -58,7 +58,7 @@ class EasySlidesImport(SongImport):
|
|||||||
song_xml = objectify.fromstring(xml)
|
song_xml = objectify.fromstring(xml)
|
||||||
self.importWizard.progressBar.setMaximum(len(song_xml.Item))
|
self.importWizard.progressBar.setMaximum(len(song_xml.Item))
|
||||||
for song in song_xml.Item:
|
for song in song_xml.Item:
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
return
|
return
|
||||||
self._parseSong(song)
|
self._parseSong(song)
|
||||||
|
|
||||||
|
@ -142,7 +142,7 @@ class EasyWorshipSongImport(SongImport):
|
|||||||
rec_count = (rec_count + record_size) / record_size
|
rec_count = (rec_count + record_size) / record_size
|
||||||
# Loop through each record within the current block
|
# Loop through each record within the current block
|
||||||
for i in range(rec_count):
|
for i in range(rec_count):
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
break
|
break
|
||||||
raw_record = db_file.read(record_size)
|
raw_record = db_file.read(record_size)
|
||||||
self.fields = self.recordStruct.unpack(raw_record)
|
self.fields = self.recordStruct.unpack(raw_record)
|
||||||
@ -216,7 +216,7 @@ class EasyWorshipSongImport(SongImport):
|
|||||||
if len(self.comments) > 5:
|
if len(self.comments) > 5:
|
||||||
self.comments += unicode(translate('SongsPlugin.EasyWorshipSongImport',
|
self.comments += unicode(translate('SongsPlugin.EasyWorshipSongImport',
|
||||||
'\n[above are Song Tags with notes imported from EasyWorship]'))
|
'\n[above are Song Tags with notes imported from EasyWorship]'))
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
break
|
break
|
||||||
if not self.finish():
|
if not self.finish():
|
||||||
self.logError(self.importSource)
|
self.logError(self.importSource)
|
||||||
|
@ -124,7 +124,7 @@ class FoilPresenterImport(SongImport):
|
|||||||
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
||||||
parser = etree.XMLParser(remove_blank_text=True)
|
parser = etree.XMLParser(remove_blank_text=True)
|
||||||
for file_path in self.importSource:
|
for file_path in self.importSource:
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
return
|
return
|
||||||
self.importWizard.incrementProgressBar(
|
self.importWizard.incrementProgressBar(
|
||||||
WizardStrings.ImportingType % os.path.basename(file_path))
|
WizardStrings.ImportingType % os.path.basename(file_path))
|
||||||
|
@ -35,7 +35,7 @@ import shutil
|
|||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
from sqlalchemy.sql import or_
|
from sqlalchemy.sql import or_
|
||||||
|
|
||||||
from openlp.core.lib import MediaManagerItem, Receiver, ItemCapabilities, PluginStatus, ServiceItemContext, Settings, \
|
from openlp.core.lib import Registry, MediaManagerItem, ItemCapabilities, PluginStatus, ServiceItemContext, Settings, \
|
||||||
UiStrings, translate, check_item_selected, create_separated_list, check_directory_exists
|
UiStrings, translate, check_item_selected, create_separated_list, check_directory_exists
|
||||||
from openlp.core.lib.ui import create_widget_action
|
from openlp.core.lib.ui import create_widget_action
|
||||||
from openlp.core.utils import AppLocation
|
from openlp.core.utils import AppLocation
|
||||||
@ -99,9 +99,9 @@ class SongMediaItem(MediaManagerItem):
|
|||||||
triggers=self.onSongMaintenanceClick)
|
triggers=self.onSongMaintenanceClick)
|
||||||
self.addSearchToToolBar()
|
self.addSearchToToolBar()
|
||||||
# Signals and slots
|
# Signals and slots
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'songs_load_list'), self.onSongListLoad)
|
Registry().register_function(u'songs_load_list', self.on_song_list_load)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'config_updated'), self.configUpdated)
|
Registry().register_function(u'config_updated', self.config_update)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'songs_preview'), self.onPreviewClick)
|
Registry().register_function(u'songs_preview', self.onPreviewClick)
|
||||||
QtCore.QObject.connect(self.searchTextEdit, QtCore.SIGNAL(u'cleared()'), self.onClearTextButtonClick)
|
QtCore.QObject.connect(self.searchTextEdit, QtCore.SIGNAL(u'cleared()'), self.onClearTextButtonClick)
|
||||||
QtCore.QObject.connect(self.searchTextEdit, QtCore.SIGNAL(u'searchTypeChanged(int)'),
|
QtCore.QObject.connect(self.searchTextEdit, QtCore.SIGNAL(u'searchTypeChanged(int)'),
|
||||||
self.onSearchTextButtonClicked)
|
self.onSearchTextButtonClicked)
|
||||||
@ -115,7 +115,7 @@ class SongMediaItem(MediaManagerItem):
|
|||||||
def onFocus(self):
|
def onFocus(self):
|
||||||
self.searchTextEdit.setFocus()
|
self.searchTextEdit.setFocus()
|
||||||
|
|
||||||
def configUpdated(self):
|
def config_update(self):
|
||||||
self.searchAsYouType = Settings().value(self.settingsSection + u'/search as type')
|
self.searchAsYouType = Settings().value(self.settingsSection + u'/search as type')
|
||||||
self.updateServiceOnEdit = Settings().value(self.settingsSection + u'/update service on edit')
|
self.updateServiceOnEdit = Settings().value(self.settingsSection + u'/update service on edit')
|
||||||
self.addSongFromService = Settings().value(self.settingsSection + u'/add song from service',)
|
self.addSongFromService = Settings().value(self.settingsSection + u'/add song from service',)
|
||||||
@ -146,7 +146,7 @@ class SongMediaItem(MediaManagerItem):
|
|||||||
UiStrings().Themes, UiStrings().SearchThemes)
|
UiStrings().Themes, UiStrings().SearchThemes)
|
||||||
])
|
])
|
||||||
self.searchTextEdit.setCurrentSearchType(Settings().value(u'%s/last search type' % self.settingsSection))
|
self.searchTextEdit.setCurrentSearchType(Settings().value(u'%s/last search type' % self.settingsSection))
|
||||||
self.configUpdated()
|
self.config_update()
|
||||||
|
|
||||||
def onSearchTextButtonClicked(self):
|
def onSearchTextButtonClicked(self):
|
||||||
# Save the current search type to the configuration.
|
# Save the current search type to the configuration.
|
||||||
@ -198,12 +198,12 @@ class SongMediaItem(MediaManagerItem):
|
|||||||
Song.search_lyrics.like(u'%' + clean_string(search_keywords) + u'%'),
|
Song.search_lyrics.like(u'%' + clean_string(search_keywords) + u'%'),
|
||||||
Song.comments.like(u'%' + search_keywords.lower() + u'%')))
|
Song.comments.like(u'%' + search_keywords.lower() + u'%')))
|
||||||
|
|
||||||
def onSongListLoad(self):
|
def on_song_list_load(self):
|
||||||
"""
|
"""
|
||||||
Handle the exit from the edit dialog and trigger remote updates
|
Handle the exit from the edit dialog and trigger remote updates
|
||||||
of songs
|
of songs
|
||||||
"""
|
"""
|
||||||
log.debug(u'onSongListLoad - start')
|
log.debug(u'on_song_list_load - start')
|
||||||
# Called to redisplay the song list screen edit from a search
|
# Called to redisplay the song list screen edit from a search
|
||||||
# or from the exit of the Song edit dialog. If remote editing is active
|
# or from the exit of the Song edit dialog. If remote editing is active
|
||||||
# Trigger it and clean up so it will not update again.
|
# Trigger it and clean up so it will not update again.
|
||||||
@ -212,7 +212,7 @@ class SongMediaItem(MediaManagerItem):
|
|||||||
item = self.buildServiceItem(self.editItem)
|
item = self.buildServiceItem(self.editItem)
|
||||||
self.service_manager.replace_service_item(item)
|
self.service_manager.replace_service_item(item)
|
||||||
self.onSearchTextButtonClicked()
|
self.onSearchTextButtonClicked()
|
||||||
log.debug(u'onSongListLoad - finished')
|
log.debug(u'on_song_list_load - finished')
|
||||||
|
|
||||||
def displayResultsSong(self, searchresults):
|
def displayResultsSong(self, searchresults):
|
||||||
log.debug(u'display results Song')
|
log.debug(u'display results Song')
|
||||||
@ -293,7 +293,7 @@ class SongMediaItem(MediaManagerItem):
|
|||||||
self.importWizard = SongImportForm(self, self.plugin)
|
self.importWizard = SongImportForm(self, self.plugin)
|
||||||
self.importWizard.exec_()
|
self.importWizard.exec_()
|
||||||
# Run song load as list may have been cancelled but some songs loaded
|
# Run song load as list may have been cancelled but some songs loaded
|
||||||
Receiver.send_message(u'songs_load_list')
|
Registry().execute(u'songs_load_list')
|
||||||
|
|
||||||
def onExportClick(self):
|
def onExportClick(self):
|
||||||
if not hasattr(self, u'exportWizard'):
|
if not hasattr(self, u'exportWizard'):
|
||||||
@ -324,7 +324,7 @@ class SongMediaItem(MediaManagerItem):
|
|||||||
self.editSongForm.loadSong(song_id, preview)
|
self.editSongForm.loadSong(song_id, preview)
|
||||||
if self.editSongForm.exec_() == QtGui.QDialog.Accepted:
|
if self.editSongForm.exec_() == QtGui.QDialog.Accepted:
|
||||||
self.autoSelectId = -1
|
self.autoSelectId = -1
|
||||||
self.onSongListLoad()
|
self.on_song_list_load()
|
||||||
self.remoteSong = song_id
|
self.remoteSong = song_id
|
||||||
self.remoteTriggered = True
|
self.remoteTriggered = True
|
||||||
item = self.buildServiceItem(remote=True)
|
item = self.buildServiceItem(remote=True)
|
||||||
@ -345,7 +345,7 @@ class SongMediaItem(MediaManagerItem):
|
|||||||
self.editSongForm.loadSong(item_id, False)
|
self.editSongForm.loadSong(item_id, False)
|
||||||
self.editSongForm.exec_()
|
self.editSongForm.exec_()
|
||||||
self.autoSelectId = -1
|
self.autoSelectId = -1
|
||||||
self.onSongListLoad()
|
self.on_song_list_load()
|
||||||
self.editItem = None
|
self.editItem = None
|
||||||
|
|
||||||
def onDeleteClick(self):
|
def onDeleteClick(self):
|
||||||
@ -397,7 +397,7 @@ class SongMediaItem(MediaManagerItem):
|
|||||||
new_song.title = u'%s <%s>' % (new_song.title,
|
new_song.title = u'%s <%s>' % (new_song.title,
|
||||||
translate('SongsPlugin.MediaItem', 'copy', 'For song cloning'))
|
translate('SongsPlugin.MediaItem', 'copy', 'For song cloning'))
|
||||||
self.plugin.manager.save_object(new_song)
|
self.plugin.manager.save_object(new_song)
|
||||||
self.onSongListLoad()
|
self.on_song_list_load()
|
||||||
|
|
||||||
def generateSlideData(self, service_item, item=None, xmlVersion=False,
|
def generateSlideData(self, service_item, item=None, xmlVersion=False,
|
||||||
remote=False, context=ServiceItemContext.Service):
|
remote=False, context=ServiceItemContext.Service):
|
||||||
|
@ -66,7 +66,7 @@ class MediaShoutImport(SongImport):
|
|||||||
songs = cursor.fetchall()
|
songs = cursor.fetchall()
|
||||||
self.importWizard.progressBar.setMaximum(len(songs))
|
self.importWizard.progressBar.setMaximum(len(songs))
|
||||||
for song in songs:
|
for song in songs:
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
break
|
break
|
||||||
cursor.execute(u'SELECT Type, Number, Text FROM Verses '
|
cursor.execute(u'SELECT Type, Number, Text FROM Verses '
|
||||||
u'WHERE Record = %s ORDER BY Type, Number' % song.Record)
|
u'WHERE Record = %s ORDER BY Type, Number' % song.Record)
|
||||||
|
@ -110,7 +110,7 @@ class OpenLP1SongImport(SongImport):
|
|||||||
self.importWizard.progressBar.setMaximum(len(songs))
|
self.importWizard.progressBar.setMaximum(len(songs))
|
||||||
for song in songs:
|
for song in songs:
|
||||||
self.setDefaults()
|
self.setDefaults()
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
break
|
break
|
||||||
song_id = song[0]
|
song_id = song[0]
|
||||||
self.title = song[1]
|
self.title = song[1]
|
||||||
@ -131,13 +131,13 @@ class OpenLP1SongImport(SongImport):
|
|||||||
u'WHERE songid = %s' % song_id)
|
u'WHERE songid = %s' % song_id)
|
||||||
author_ids = cursor.fetchall()
|
author_ids = cursor.fetchall()
|
||||||
for author_id in author_ids:
|
for author_id in author_ids:
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
break
|
break
|
||||||
for author in authors:
|
for author in authors:
|
||||||
if author[0] == author_id[0]:
|
if author[0] == author_id[0]:
|
||||||
self.parseAuthor(author[1])
|
self.parseAuthor(author[1])
|
||||||
break
|
break
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
break
|
break
|
||||||
if db_has_tracks:
|
if db_has_tracks:
|
||||||
cursor.execute(u'-- types int, int')
|
cursor.execute(u'-- types int, int')
|
||||||
@ -146,14 +146,14 @@ class OpenLP1SongImport(SongImport):
|
|||||||
u'WHERE songid = %s ORDER BY listindex' % song_id)
|
u'WHERE songid = %s ORDER BY listindex' % song_id)
|
||||||
track_ids = cursor.fetchall()
|
track_ids = cursor.fetchall()
|
||||||
for track_id, listindex in track_ids:
|
for track_id, listindex in track_ids:
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
break
|
break
|
||||||
for track in tracks:
|
for track in tracks:
|
||||||
if track[0] == track_id:
|
if track[0] == track_id:
|
||||||
media_file = self.expandMediaFile(track[1])
|
media_file = self.expandMediaFile(track[1])
|
||||||
self.addMediaFile(media_file, listindex)
|
self.addMediaFile(media_file, listindex)
|
||||||
break
|
break
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
break
|
break
|
||||||
if not self.finish():
|
if not self.finish():
|
||||||
self.logError(self.importSource)
|
self.logError(self.importSource)
|
||||||
|
@ -225,6 +225,6 @@ class OpenLPSongImport(SongImport):
|
|||||||
progressDialog.setLabelText(WizardStrings.ImportingType % new_song.title)
|
progressDialog.setLabelText(WizardStrings.ImportingType % new_song.title)
|
||||||
else:
|
else:
|
||||||
self.importWizard.incrementProgressBar(WizardStrings.ImportingType % new_song.title)
|
self.importWizard.incrementProgressBar(WizardStrings.ImportingType % new_song.title)
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
break
|
break
|
||||||
engine.dispose()
|
engine.dispose()
|
||||||
|
@ -77,7 +77,7 @@ class OooImport(SongImport):
|
|||||||
return
|
return
|
||||||
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
||||||
for filename in self.importSource:
|
for filename in self.importSource:
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
break
|
break
|
||||||
filename = unicode(filename)
|
filename = unicode(filename)
|
||||||
if os.path.isfile(filename):
|
if os.path.isfile(filename):
|
||||||
@ -189,7 +189,7 @@ class OooImport(SongImport):
|
|||||||
slides = doc.getDrawPages()
|
slides = doc.getDrawPages()
|
||||||
text = u''
|
text = u''
|
||||||
for slide_no in range(slides.getCount()):
|
for slide_no in range(slides.getCount()):
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
self.importWizard.incrementProgressBar(u'Import cancelled', 0)
|
self.importWizard.incrementProgressBar(u'Import cancelled', 0)
|
||||||
return
|
return
|
||||||
slide = slides.getByIndex(slide_no)
|
slide = slides.getByIndex(slide_no)
|
||||||
|
@ -63,7 +63,7 @@ class OpenLyricsImport(SongImport):
|
|||||||
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
||||||
parser = etree.XMLParser(remove_blank_text=True)
|
parser = etree.XMLParser(remove_blank_text=True)
|
||||||
for file_path in self.importSource:
|
for file_path in self.importSource:
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
return
|
return
|
||||||
self.importWizard.incrementProgressBar(WizardStrings.ImportingType % os.path.basename(file_path))
|
self.importWizard.incrementProgressBar(WizardStrings.ImportingType % os.path.basename(file_path))
|
||||||
try:
|
try:
|
||||||
|
@ -113,7 +113,7 @@ class OpenSongImport(SongImport):
|
|||||||
def doImport(self):
|
def doImport(self):
|
||||||
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
||||||
for filename in self.importSource:
|
for filename in self.importSource:
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
return
|
return
|
||||||
song_file = open(filename)
|
song_file = open(filename)
|
||||||
self.doImportFile(song_file)
|
self.doImportFile(song_file)
|
||||||
|
@ -106,7 +106,7 @@ class PowerSongImport(SongImport):
|
|||||||
return
|
return
|
||||||
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
||||||
for file in self.importSource:
|
for file in self.importSource:
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
return
|
return
|
||||||
self.setDefaults()
|
self.setDefaults()
|
||||||
parse_error = False
|
parse_error = False
|
||||||
|
@ -100,7 +100,7 @@ class SofImport(OooImport):
|
|||||||
try:
|
try:
|
||||||
paragraphs = self.document.getText().createEnumeration()
|
paragraphs = self.document.getText().createEnumeration()
|
||||||
while paragraphs.hasMoreElements():
|
while paragraphs.hasMoreElements():
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
return
|
return
|
||||||
paragraph = paragraphs.nextElement()
|
paragraph = paragraphs.nextElement()
|
||||||
if paragraph.supportsService("com.sun.star.text.Paragraph"):
|
if paragraph.supportsService("com.sun.star.text.Paragraph"):
|
||||||
|
@ -109,7 +109,7 @@ class SongBeamerImport(SongImport):
|
|||||||
return
|
return
|
||||||
for file in self.importSource:
|
for file in self.importSource:
|
||||||
# TODO: check that it is a valid SongBeamer file
|
# TODO: check that it is a valid SongBeamer file
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
return
|
return
|
||||||
self.setDefaults()
|
self.setDefaults()
|
||||||
self.currentVerse = u''
|
self.currentVerse = u''
|
||||||
|
@ -34,7 +34,7 @@ import os
|
|||||||
|
|
||||||
from PyQt4 import QtCore
|
from PyQt4 import QtCore
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, translate, check_directory_exists
|
from openlp.core.lib import Registry, translate, check_directory_exists
|
||||||
from openlp.core.ui.wizard import WizardStrings
|
from openlp.core.ui.wizard import WizardStrings
|
||||||
from openlp.core.utils import AppLocation
|
from openlp.core.utils import AppLocation
|
||||||
from openlp.plugins.songs.lib import clean_song, VerseType
|
from openlp.plugins.songs.lib import clean_song, VerseType
|
||||||
@ -81,9 +81,9 @@ class SongImport(QtCore.QObject):
|
|||||||
log.debug(self.importSource)
|
log.debug(self.importSource)
|
||||||
self.importWizard = None
|
self.importWizard = None
|
||||||
self.song = None
|
self.song = None
|
||||||
self.stopImportFlag = False
|
self.stop_import_flag = False
|
||||||
self.setDefaults()
|
self.setDefaults()
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'openlp_stop_wizard'), self.stopImport)
|
Registry().register_function(u'openlp_stop_wizard', self.stop_import)
|
||||||
|
|
||||||
def setDefaults(self):
|
def setDefaults(self):
|
||||||
"""
|
"""
|
||||||
@ -133,12 +133,12 @@ class SongImport(QtCore.QObject):
|
|||||||
self.importWizard.errorSaveToButton.setVisible(True)
|
self.importWizard.errorSaveToButton.setVisible(True)
|
||||||
self.importWizard.errorReportTextEdit.append(u'- %s (%s)' % (filepath, reason))
|
self.importWizard.errorReportTextEdit.append(u'- %s (%s)' % (filepath, reason))
|
||||||
|
|
||||||
def stopImport(self):
|
def stop_import(self):
|
||||||
"""
|
"""
|
||||||
Sets the flag for importers to stop their import
|
Sets the flag for importers to stop their import
|
||||||
"""
|
"""
|
||||||
log.debug(u'Stopping songs import')
|
log.debug(u'Stopping songs import')
|
||||||
self.stopImportFlag = True
|
self.stop_import_flag = True
|
||||||
|
|
||||||
def register(self, import_wizard):
|
def register(self, import_wizard):
|
||||||
self.importWizard = import_wizard
|
self.importWizard = import_wizard
|
||||||
|
@ -83,7 +83,7 @@ class SongProImport(SongImport):
|
|||||||
tag = u''
|
tag = u''
|
||||||
text = u''
|
text = u''
|
||||||
for file_line in songs_file:
|
for file_line in songs_file:
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
break
|
break
|
||||||
file_line = unicode(file_line, u'cp1252')
|
file_line = unicode(file_line, u'cp1252')
|
||||||
file_text = file_line.rstrip()
|
file_text = file_line.rstrip()
|
||||||
|
@ -105,7 +105,7 @@ class SongShowPlusImport(SongImport):
|
|||||||
return
|
return
|
||||||
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
||||||
for file in self.importSource:
|
for file in self.importSource:
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
return
|
return
|
||||||
self.sspVerseOrderList = []
|
self.sspVerseOrderList = []
|
||||||
other_count = 0
|
other_count = 0
|
||||||
|
@ -66,7 +66,7 @@ class SundayPlusImport(SongImport):
|
|||||||
def doImport(self):
|
def doImport(self):
|
||||||
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
||||||
for filename in self.importSource:
|
for filename in self.importSource:
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
return
|
return
|
||||||
song_file = open(filename)
|
song_file = open(filename)
|
||||||
self.doImportFile(song_file)
|
self.doImportFile(song_file)
|
||||||
|
@ -108,7 +108,7 @@ class WowImport(SongImport):
|
|||||||
if isinstance(self.importSource, list):
|
if isinstance(self.importSource, list):
|
||||||
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
self.importWizard.progressBar.setMaximum(len(self.importSource))
|
||||||
for source in self.importSource:
|
for source in self.importSource:
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
return
|
return
|
||||||
self.setDefaults()
|
self.setDefaults()
|
||||||
song_data = open(source, 'rb')
|
song_data = open(source, 'rb')
|
||||||
|
@ -96,7 +96,7 @@ class ZionWorxImport(SongImport):
|
|||||||
log.info(u'%s records found in CSV file' % num_records)
|
log.info(u'%s records found in CSV file' % num_records)
|
||||||
self.importWizard.progressBar.setMaximum(num_records)
|
self.importWizard.progressBar.setMaximum(num_records)
|
||||||
for index, record in enumerate(records, 1):
|
for index, record in enumerate(records, 1):
|
||||||
if self.stopImportFlag:
|
if self.stop_import_flag:
|
||||||
return
|
return
|
||||||
self.setDefaults()
|
self.setDefaults()
|
||||||
try:
|
try:
|
||||||
|
@ -29,10 +29,11 @@
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, translate
|
from openlp.core.lib import Registry, translate
|
||||||
from openlp.plugins.songusage.lib.db import SongUsageItem
|
from openlp.plugins.songusage.lib.db import SongUsageItem
|
||||||
from songusagedeletedialog import Ui_SongUsageDeleteDialog
|
from songusagedeletedialog import Ui_SongUsageDeleteDialog
|
||||||
|
|
||||||
|
|
||||||
class SongUsageDeleteForm(QtGui.QDialog, Ui_SongUsageDeleteDialog):
|
class SongUsageDeleteForm(QtGui.QDialog, Ui_SongUsageDeleteDialog):
|
||||||
"""
|
"""
|
||||||
Class documentation goes here.
|
Class documentation goes here.
|
||||||
@ -57,11 +58,21 @@ class SongUsageDeleteForm(QtGui.QDialog, Ui_SongUsageDeleteDialog):
|
|||||||
if ret == QtGui.QMessageBox.Yes:
|
if ret == QtGui.QMessageBox.Yes:
|
||||||
deleteDate = self.deleteCalendar.selectedDate().toPyDate()
|
deleteDate = self.deleteCalendar.selectedDate().toPyDate()
|
||||||
self.manager.delete_all_objects(SongUsageItem, SongUsageItem.usagedate <= deleteDate)
|
self.manager.delete_all_objects(SongUsageItem, SongUsageItem.usagedate <= deleteDate)
|
||||||
Receiver.send_message(u'openlp_information_message', {
|
self.main_window.information_message(
|
||||||
u'title': translate('SongUsagePlugin.SongUsageDeleteForm', 'Deletion Successful'),
|
translate('SongUsagePlugin.SongUsageDeleteForm', 'Deletion Successful'),
|
||||||
u'message': translate(
|
translate(
|
||||||
'SongUsagePlugin.SongUsageDeleteForm', 'All requested data has been deleted successfully. ')}
|
'SongUsagePlugin.SongUsageDeleteForm', 'All requested data has been deleted successfully. ')
|
||||||
)
|
)
|
||||||
self.accept()
|
self.accept()
|
||||||
else:
|
else:
|
||||||
self.reject()
|
self.reject()
|
||||||
|
|
||||||
|
def _get_main_window(self):
|
||||||
|
"""
|
||||||
|
Adds the main window to the class dynamically
|
||||||
|
"""
|
||||||
|
if not hasattr(self, u'_main_window'):
|
||||||
|
self._main_window = Registry().get(u'main_window')
|
||||||
|
return self._main_window
|
||||||
|
|
||||||
|
main_window = property(_get_main_window)
|
@ -33,7 +33,7 @@ import os
|
|||||||
from PyQt4 import QtGui
|
from PyQt4 import QtGui
|
||||||
from sqlalchemy.sql import and_
|
from sqlalchemy.sql import and_
|
||||||
|
|
||||||
from openlp.core.lib import Receiver, Settings, translate, check_directory_exists
|
from openlp.core.lib import Registry, Settings, translate, check_directory_exists
|
||||||
from openlp.plugins.songusage.lib.db import SongUsageItem
|
from openlp.plugins.songusage.lib.db import SongUsageItem
|
||||||
from songusagedetaildialog import Ui_SongUsageDetailDialog
|
from songusagedetaildialog import Ui_SongUsageDetailDialog
|
||||||
|
|
||||||
@ -81,11 +81,11 @@ class SongUsageDetailForm(QtGui.QDialog, Ui_SongUsageDetailDialog):
|
|||||||
log.debug(u'accept')
|
log.debug(u'accept')
|
||||||
path = self.fileLineEdit.text()
|
path = self.fileLineEdit.text()
|
||||||
if not path:
|
if not path:
|
||||||
Receiver.send_message(u'openlp_error_message', {
|
self.main_window.error_message(
|
||||||
u'title': translate('SongUsagePlugin.SongUsageDetailForm', 'Output Path Not Selected'),
|
translate('SongUsagePlugin.SongUsageDetailForm', 'Output Path Not Selected'),
|
||||||
u'message': translate(
|
translate('SongUsagePlugin.SongUsageDetailForm', 'You have not set a valid output location for your'
|
||||||
'SongUsagePlugin.SongUsageDetailForm', 'You have not set a valid output location for your song usage '
|
' song usage report. Please select an existing path on your computer.')
|
||||||
'report. Please select an existing path on your computer.')})
|
)
|
||||||
return
|
return
|
||||||
check_directory_exists(path)
|
check_directory_exists(path)
|
||||||
filename = translate('SongUsagePlugin.SongUsageDetailForm', 'usage_detail_%s_%s.txt') % (
|
filename = translate('SongUsagePlugin.SongUsageDetailForm', 'usage_detail_%s_%s.txt') % (
|
||||||
@ -108,13 +108,24 @@ class SongUsageDetailForm(QtGui.QDialog, Ui_SongUsageDetailDialog):
|
|||||||
instance.usagetime, instance.title, instance.copyright,
|
instance.usagetime, instance.title, instance.copyright,
|
||||||
instance.ccl_number, instance.authors, instance.plugin_name, instance.source)
|
instance.ccl_number, instance.authors, instance.plugin_name, instance.source)
|
||||||
fileHandle.write(record.encode(u'utf-8'))
|
fileHandle.write(record.encode(u'utf-8'))
|
||||||
Receiver.send_message(u'openlp_information_message', {
|
self.main_window.information_message(
|
||||||
u'title': translate('SongUsagePlugin.SongUsageDetailForm', 'Report Creation'),
|
translate('SongUsagePlugin.SongUsageDetailForm', 'Report Creation'),
|
||||||
u'message': translate('SongUsagePlugin.SongUsageDetailForm', 'Report \n%s \n'
|
translate('SongUsagePlugin.SongUsageDetailForm', 'Report \n%s \n'
|
||||||
'has been successfully created. ') % outname})
|
'has been successfully created. ') % outname
|
||||||
|
)
|
||||||
except IOError:
|
except IOError:
|
||||||
log.exception(u'Failed to write out song usage records')
|
log.exception(u'Failed to write out song usage records')
|
||||||
finally:
|
finally:
|
||||||
if fileHandle:
|
if fileHandle:
|
||||||
fileHandle.close()
|
fileHandle.close()
|
||||||
self.close()
|
self.close()
|
||||||
|
|
||||||
|
def _get_main_window(self):
|
||||||
|
"""
|
||||||
|
Adds the main window to the class dynamically
|
||||||
|
"""
|
||||||
|
if not hasattr(self, u'_main_window'):
|
||||||
|
self._main_window = Registry().get(u'main_window')
|
||||||
|
return self._main_window
|
||||||
|
|
||||||
|
main_window = property(_get_main_window)
|
@ -32,7 +32,7 @@ from datetime import datetime
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Plugin, Receiver, Settings, StringContent, build_icon, translate
|
from openlp.core.lib import Plugin, Registry, Settings, StringContent, build_icon, translate
|
||||||
from openlp.core.lib.db import Manager
|
from openlp.core.lib.db import Manager
|
||||||
from openlp.core.lib.ui import create_action
|
from openlp.core.lib.ui import create_action
|
||||||
from openlp.core.utils.actions import ActionList
|
from openlp.core.utils.actions import ActionList
|
||||||
@ -123,10 +123,8 @@ class SongUsagePlugin(Plugin):
|
|||||||
def initialise(self):
|
def initialise(self):
|
||||||
log.info(u'SongUsage Initialising')
|
log.info(u'SongUsage Initialising')
|
||||||
Plugin.initialise(self)
|
Plugin.initialise(self)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'slidecontroller_live_started'),
|
Registry().register_function(u'slidecontroller_live_started', self.display_song_usage)
|
||||||
self.displaySongUsage)
|
Registry().register_function(u'print_service_started', self.print_song_usage)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'print_service_started'),
|
|
||||||
self.printSongUsage)
|
|
||||||
self.songUsageActive = Settings().value(self.settingsSection + u'/active')
|
self.songUsageActive = Settings().value(self.settingsSection + u'/active')
|
||||||
# Set the button and checkbox state
|
# Set the button and checkbox state
|
||||||
self.setButtonState()
|
self.setButtonState()
|
||||||
@ -185,13 +183,13 @@ class SongUsagePlugin(Plugin):
|
|||||||
self.songUsageStatus.blockSignals(False)
|
self.songUsageStatus.blockSignals(False)
|
||||||
|
|
||||||
|
|
||||||
def displaySongUsage(self, item):
|
def display_song_usage(self, item):
|
||||||
"""
|
"""
|
||||||
Song Usage for which has been displayed
|
Song Usage for which has been displayed
|
||||||
"""
|
"""
|
||||||
self._add_song_usage(translate('SongUsagePlugin', 'display'), item)
|
self._add_song_usage(translate('SongUsagePlugin', 'display'), item)
|
||||||
|
|
||||||
def printSongUsage(self, item):
|
def print_song_usage(self, item):
|
||||||
"""
|
"""
|
||||||
Song Usage for which has been printed
|
Song Usage for which has been printed
|
||||||
"""
|
"""
|
||||||
|
@ -1,46 +0,0 @@
|
|||||||
#!/usr/bin/env python
|
|
||||||
# -*- coding: utf-8 -*-
|
|
||||||
# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
|
|
||||||
|
|
||||||
###############################################################################
|
|
||||||
# OpenLP - Open Source Lyrics Projection #
|
|
||||||
# --------------------------------------------------------------------------- #
|
|
||||||
# Copyright (c) 2008-2011 Raoul Snyman #
|
|
||||||
# Portions copyright (c) 2008-2011 Tim Bentley, Gerald Britton, Jonathan #
|
|
||||||
# Corwin, Samuel Findlay, Michael Gorven, Scott Guerrieri, Matthias Hub, #
|
|
||||||
# Meinert Jordan, Armin Köhler, Edwin Lunando, Joshua Miller, Stevan Pettit, #
|
|
||||||
# Andreas Preikschat, Mattias Põldaru, Christian Richter, Philip Ridout, #
|
|
||||||
# Simon Scudder, Jeffrey Smith, Maikel Stuivenberg, Martin Thompson, Jon #
|
|
||||||
# Tibble, Dave Warnock, Frode Woldsund #
|
|
||||||
# --------------------------------------------------------------------------- #
|
|
||||||
# This program is free software; you can redistribute it and/or modify it #
|
|
||||||
# under the terms of the GNU General Public License as published by the Free #
|
|
||||||
# Software Foundation; version 2 of the License. #
|
|
||||||
# #
|
|
||||||
# This program is distributed in the hope that it will be useful, but WITHOUT #
|
|
||||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or #
|
|
||||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for #
|
|
||||||
# more details. #
|
|
||||||
# #
|
|
||||||
# You should have received a copy of the GNU General Public License along #
|
|
||||||
# with this program; if not, write to the Free Software Foundation, Inc., 59 #
|
|
||||||
# Temple Place, Suite 330, Boston, MA 02111-1307 USA #
|
|
||||||
###############################################################################
|
|
||||||
|
|
||||||
"""
|
|
||||||
Configuration file for pytest framework.
|
|
||||||
"""
|
|
||||||
|
|
||||||
from openlp.core import main as openlp_main
|
|
||||||
|
|
||||||
|
|
||||||
# Test function argument to make openlp gui instance persistent for all tests.
|
|
||||||
# All test cases have to access the same instance. To allow create multiple
|
|
||||||
# instances it would be necessary use diffrent configuraion and data files.
|
|
||||||
# Created instance will use your OpenLP settings.
|
|
||||||
def pytest_funcarg__openlpapp(request):
|
|
||||||
def setup():
|
|
||||||
return openlp_main(['--testing'])
|
|
||||||
def teardown(app):
|
|
||||||
pass
|
|
||||||
return request.cached_setup(setup=setup, teardown=teardown, scope='session')
|
|
@ -11,12 +11,12 @@ TESTPATH = os.path.abspath(os.path.join(os.path.dirname(__file__), u'..', u'..',
|
|||||||
|
|
||||||
class TestRegistry(TestCase):
|
class TestRegistry(TestCase):
|
||||||
|
|
||||||
def registry_basic_test(self):
|
def registry_service_test(self):
|
||||||
"""
|
"""
|
||||||
Test the registry creation and its usage
|
Test the registry creation and its usage
|
||||||
"""
|
"""
|
||||||
# GIVEN: A new registry
|
# GIVEN: A new registry
|
||||||
registry = Registry.create()
|
Registry.create()
|
||||||
|
|
||||||
# WHEN: I add a component it should save it
|
# WHEN: I add a component it should save it
|
||||||
mock_1 = MagicMock()
|
mock_1 = MagicMock()
|
||||||
@ -46,3 +46,37 @@ class TestRegistry(TestCase):
|
|||||||
temp = Registry().get(u'test1')
|
temp = Registry().get(u'test1')
|
||||||
self.assertEqual(context.exception[0], u'Service test1 not found in list',
|
self.assertEqual(context.exception[0], u'Service test1 not found in list',
|
||||||
u'KeyError exception should have been thrown for deleted service')
|
u'KeyError exception should have been thrown for deleted service')
|
||||||
|
|
||||||
|
def registry_function_test(self):
|
||||||
|
"""
|
||||||
|
Test the registry function creation and their usages
|
||||||
|
"""
|
||||||
|
# GIVEN: An existing registry register a function
|
||||||
|
Registry.create()
|
||||||
|
Registry().register_function(u'test1', self.dummy_function_1)
|
||||||
|
|
||||||
|
# WHEN: I execute the function
|
||||||
|
return_value = Registry().execute(u'test1')
|
||||||
|
|
||||||
|
# THEN: I expect then function to have been called and a return given
|
||||||
|
self.assertEqual(return_value[0], u'function_1', u'A return value is provided and matches')
|
||||||
|
|
||||||
|
# WHEN: I execute the a function with the same reference and execute the function
|
||||||
|
Registry().register_function(u'test1', self.dummy_function_1)
|
||||||
|
return_value = Registry().execute(u'test1')
|
||||||
|
|
||||||
|
# THEN: I expect then function to have been called and a return given
|
||||||
|
self.assertEqual(return_value, [u'function_1', u'function_1'], u'A return value list is provided and matches')
|
||||||
|
|
||||||
|
# WHEN: I execute the a 2nd function with the different reference and execute the function
|
||||||
|
Registry().register_function(u'test2', self.dummy_function_2)
|
||||||
|
return_value = Registry().execute(u'test2')
|
||||||
|
|
||||||
|
# THEN: I expect then function to have been called and a return given
|
||||||
|
self.assertEqual(return_value[0], u'function_2', u'A return value is provided and matches')
|
||||||
|
|
||||||
|
def dummy_function_1(self):
|
||||||
|
return "function_1"
|
||||||
|
|
||||||
|
def dummy_function_2(self):
|
||||||
|
return "function_2"
|
@ -14,7 +14,7 @@ class TestStartNoteDialog(TestCase):
|
|||||||
"""
|
"""
|
||||||
Create the UI
|
Create the UI
|
||||||
"""
|
"""
|
||||||
registry = Registry.create()
|
Registry.create()
|
||||||
self.app = QtGui.QApplication([])
|
self.app = QtGui.QApplication([])
|
||||||
self.main_window = QtGui.QMainWindow()
|
self.main_window = QtGui.QMainWindow()
|
||||||
Registry().register(u'main_window', self.main_window)
|
Registry().register(u'main_window', self.main_window)
|
||||||
@ -36,7 +36,7 @@ class TestStartNoteDialog(TestCase):
|
|||||||
self.form.text_edit.setPlainText(u'')
|
self.form.text_edit.setPlainText(u'')
|
||||||
|
|
||||||
# WHEN displaying the UI and pressing enter
|
# WHEN displaying the UI and pressing enter
|
||||||
with patch(u'PyQt4.QtGui.QDialog') as mocked_exec:
|
with patch(u'PyQt4.QtGui.QDialog.exec_'):
|
||||||
self.form.exec_()
|
self.form.exec_()
|
||||||
okWidget = self.form.button_box.button(self.form.button_box.Save)
|
okWidget = self.form.button_box.button(self.form.button_box.Save)
|
||||||
QtTest.QTest.mouseClick(okWidget, QtCore.Qt.LeftButton)
|
QtTest.QTest.mouseClick(okWidget, QtCore.Qt.LeftButton)
|
||||||
@ -47,7 +47,7 @@ class TestStartNoteDialog(TestCase):
|
|||||||
# WHEN displaying the UI, having set the text and pressing enter
|
# WHEN displaying the UI, having set the text and pressing enter
|
||||||
text = u'OpenLP is the best worship software'
|
text = u'OpenLP is the best worship software'
|
||||||
self.form.text_edit.setPlainText(text)
|
self.form.text_edit.setPlainText(text)
|
||||||
with patch(u'PyQt4.QtGui.QDialog') as mocked_exec:
|
with patch(u'PyQt4.QtGui.QDialog.exec_'):
|
||||||
self.form.exec_()
|
self.form.exec_()
|
||||||
okWidget = self.form.button_box.button(self.form.button_box.Save)
|
okWidget = self.form.button_box.button(self.form.button_box.Save)
|
||||||
QtTest.QTest.mouseClick(okWidget, QtCore.Qt.LeftButton)
|
QtTest.QTest.mouseClick(okWidget, QtCore.Qt.LeftButton)
|
||||||
@ -57,7 +57,7 @@ class TestStartNoteDialog(TestCase):
|
|||||||
|
|
||||||
# WHEN displaying the UI, having set the text and pressing enter
|
# WHEN displaying the UI, having set the text and pressing enter
|
||||||
self.form.text_edit.setPlainText(u'')
|
self.form.text_edit.setPlainText(u'')
|
||||||
with patch(u'PyQt4.QtGui.QDialog') as mocked_exec:
|
with patch(u'PyQt4.QtGui.QDialog.exec_'):
|
||||||
self.form.exec_()
|
self.form.exec_()
|
||||||
self.form.text_edit.setPlainText(text)
|
self.form.text_edit.setPlainText(text)
|
||||||
okWidget = self.form.button_box.button(self.form.button_box.Save)
|
okWidget = self.form.button_box.button(self.form.button_box.Save)
|
||||||
|
@ -14,7 +14,7 @@ class TestStartTimeDialog(TestCase):
|
|||||||
"""
|
"""
|
||||||
Create the UI
|
Create the UI
|
||||||
"""
|
"""
|
||||||
registry = Registry.create()
|
Registry.create()
|
||||||
self.app = QtGui.QApplication([])
|
self.app = QtGui.QApplication([])
|
||||||
self.main_window = QtGui.QMainWindow()
|
self.main_window = QtGui.QMainWindow()
|
||||||
Registry().register(u'main_window', self.main_window)
|
Registry().register(u'main_window', self.main_window)
|
||||||
@ -67,7 +67,7 @@ class TestStartTimeDialog(TestCase):
|
|||||||
|
|
||||||
# WHEN displaying the UI and pressing enter
|
# WHEN displaying the UI and pressing enter
|
||||||
self.form.item = {u'service_item': mocked_serviceitem}
|
self.form.item = {u'service_item': mocked_serviceitem}
|
||||||
with patch(u'PyQt4.QtGui.QDialog') as mocked_exec:
|
with patch(u'PyQt4.QtGui.QDialog.exec_'):
|
||||||
self.form.exec_()
|
self.form.exec_()
|
||||||
okWidget = self.form.button_box.button(self.form.button_box.Ok)
|
okWidget = self.form.button_box.button(self.form.button_box.Ok)
|
||||||
QtTest.QTest.mouseClick(okWidget, QtCore.Qt.LeftButton)
|
QtTest.QTest.mouseClick(okWidget, QtCore.Qt.LeftButton)
|
||||||
@ -80,7 +80,7 @@ class TestStartTimeDialog(TestCase):
|
|||||||
|
|
||||||
# WHEN displaying the UI, changing the time to 2min 3secs and pressing enter
|
# WHEN displaying the UI, changing the time to 2min 3secs and pressing enter
|
||||||
self.form.item = {u'service_item': mocked_serviceitem}
|
self.form.item = {u'service_item': mocked_serviceitem}
|
||||||
with patch(u'PyQt4.QtGui.QDialog') as mocked_exec:
|
with patch(u'PyQt4.QtGui.QDialog.exec_'):
|
||||||
self.form.exec_()
|
self.form.exec_()
|
||||||
self.form.minuteSpinBox.setValue(2)
|
self.form.minuteSpinBox.setValue(2)
|
||||||
self.form.secondSpinBox.setValue(3)
|
self.form.secondSpinBox.setValue(3)
|
||||||
|
60
tests/run.py
60
tests/run.py
@ -1,60 +0,0 @@
|
|||||||
#!/usr/bin/env python
|
|
||||||
# -*- coding: utf-8 -*-
|
|
||||||
# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
|
|
||||||
|
|
||||||
###############################################################################
|
|
||||||
# OpenLP - Open Source Lyrics Projection #
|
|
||||||
# --------------------------------------------------------------------------- #
|
|
||||||
# Copyright (c) 2008-2011 Raoul Snyman #
|
|
||||||
# Portions copyright (c) 2008-2011 Tim Bentley, Gerald Britton, Jonathan #
|
|
||||||
# Corwin, Samuel Findlay, Michael Gorven, Scott Guerrieri, Matthias Hub, #
|
|
||||||
# Meinert Jordan, Armin Köhler, Edwin Lunando, Joshua Miller, Stevan Pettit, #
|
|
||||||
# Andreas Preikschat, Mattias Põldaru, Christian Richter, Philip Ridout, #
|
|
||||||
# Simon Scudder, Jeffrey Smith, Maikel Stuivenberg, Martin Thompson, Jon #
|
|
||||||
# Tibble, Dave Warnock, Frode Woldsund #
|
|
||||||
# --------------------------------------------------------------------------- #
|
|
||||||
# This program is free software; you can redistribute it and/or modify it #
|
|
||||||
# under the terms of the GNU General Public License as published by the Free #
|
|
||||||
# Software Foundation; version 2 of the License. #
|
|
||||||
# #
|
|
||||||
# This program is distributed in the hope that it will be useful, but WITHOUT #
|
|
||||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or #
|
|
||||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for #
|
|
||||||
# more details. #
|
|
||||||
# #
|
|
||||||
# You should have received a copy of the GNU General Public License along #
|
|
||||||
# with this program; if not, write to the Free Software Foundation, Inc., 59 #
|
|
||||||
# Temple Place, Suite 330, Boston, MA 02111-1307 USA #
|
|
||||||
###############################################################################
|
|
||||||
|
|
||||||
"""
|
|
||||||
This script is used to run set of automated tests of OpenLP. To start tests,
|
|
||||||
simply run this script::
|
|
||||||
|
|
||||||
@:~$ ./run.py
|
|
||||||
|
|
||||||
"""
|
|
||||||
|
|
||||||
import os
|
|
||||||
import sys
|
|
||||||
|
|
||||||
TESTS_PATH = os.path.dirname(os.path.abspath(__file__))
|
|
||||||
SRC_PATH = os.path.join(TESTS_PATH, '..')
|
|
||||||
|
|
||||||
PYTEST_OPTIONS = [TESTS_PATH]
|
|
||||||
|
|
||||||
# Extend python PATH with openlp source
|
|
||||||
sys.path.insert(0, SRC_PATH)
|
|
||||||
|
|
||||||
# Python testing framework
|
|
||||||
# http://pytest.org
|
|
||||||
import pytest
|
|
||||||
|
|
||||||
|
|
||||||
def main():
|
|
||||||
print 'pytest options:', PYTEST_OPTIONS
|
|
||||||
pytest.main(PYTEST_OPTIONS)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == u'__main__':
|
|
||||||
main()
|
|
@ -1,37 +0,0 @@
|
|||||||
#!/usr/bin/env python
|
|
||||||
# -*- coding: utf-8 -*-
|
|
||||||
# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
|
|
||||||
|
|
||||||
###############################################################################
|
|
||||||
# OpenLP - Open Source Lyrics Projection #
|
|
||||||
# --------------------------------------------------------------------------- #
|
|
||||||
# Copyright (c) 2008-2011 Raoul Snyman #
|
|
||||||
# Portions copyright (c) 2008-2011 Tim Bentley, Gerald Britton, Jonathan #
|
|
||||||
# Corwin, Samuel Findlay, Michael Gorven, Scott Guerrieri, Matthias Hub, #
|
|
||||||
# Meinert Jordan, Armin Köhler, Edwin Lunando, Joshua Miller, Stevan Pettit, #
|
|
||||||
# Andreas Preikschat, Mattias Põldaru, Christian Richter, Philip Ridout, #
|
|
||||||
# Simon Scudder, Jeffrey Smith, Maikel Stuivenberg, Martin Thompson, Jon #
|
|
||||||
# Tibble, Dave Warnock, Frode Woldsund #
|
|
||||||
# --------------------------------------------------------------------------- #
|
|
||||||
# This program is free software; you can redistribute it and/or modify it #
|
|
||||||
# under the terms of the GNU General Public License as published by the Free #
|
|
||||||
# Software Foundation; version 2 of the License. #
|
|
||||||
# #
|
|
||||||
# This program is distributed in the hope that it will be useful, but WITHOUT #
|
|
||||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or #
|
|
||||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for #
|
|
||||||
# more details. #
|
|
||||||
# #
|
|
||||||
# You should have received a copy of the GNU General Public License along #
|
|
||||||
# with this program; if not, write to the Free Software Foundation, Inc., 59 #
|
|
||||||
# Temple Place, Suite 330, Boston, MA 02111-1307 USA #
|
|
||||||
###############################################################################
|
|
||||||
|
|
||||||
from openlp.core import OpenLP
|
|
||||||
from openlp.core.ui.mainwindow import MainWindow
|
|
||||||
|
|
||||||
|
|
||||||
def test_start_app(openlpapp):
|
|
||||||
assert type(openlpapp) == OpenLP
|
|
||||||
assert type(openlpapp.mainWindow) == MainWindow
|
|
||||||
assert unicode(openlpapp.mainWindow.windowTitle()) == u'OpenLP 2.1'
|
|
Loading…
Reference in New Issue
Block a user