forked from openlp/openlp
Merged trunk
This commit is contained in:
commit
c613773bfb
openlp
core
plugins
@ -81,6 +81,7 @@ class ServiceItem(object):
|
|||||||
self.notes = u''
|
self.notes = u''
|
||||||
self.from_plugin = False
|
self.from_plugin = False
|
||||||
self.capabilities = []
|
self.capabilities = []
|
||||||
|
self.isValid = True
|
||||||
|
|
||||||
def add_capability(self, capability):
|
def add_capability(self, capability):
|
||||||
self.capabilities.append(capability)
|
self.capabilities.append(capability)
|
||||||
|
@ -44,7 +44,7 @@ class GeneralTab(SettingsTab):
|
|||||||
settings = QtCore.QSettings()
|
settings = QtCore.QSettings()
|
||||||
settings.beginGroup(self.settingsSection)
|
settings.beginGroup(self.settingsSection)
|
||||||
self.MonitorNumber = settings.value(u'monitor',
|
self.MonitorNumber = settings.value(u'monitor',
|
||||||
QtCore.QVariant(self.screens.monitor_number)).toInt()[0]
|
QtCore.QVariant(self.screens.display_count - 1)).toInt()[0]
|
||||||
self.screens.set_current_display(self.MonitorNumber)
|
self.screens.set_current_display(self.MonitorNumber)
|
||||||
self.screens.monitor_number = self.MonitorNumber
|
self.screens.monitor_number = self.MonitorNumber
|
||||||
self.DisplayOnMonitor = settings.value(
|
self.DisplayOnMonitor = settings.value(
|
||||||
|
@ -101,6 +101,7 @@ class ServiceManager(QtGui.QWidget):
|
|||||||
self.parent = parent
|
self.parent = parent
|
||||||
self.serviceItems = []
|
self.serviceItems = []
|
||||||
self.serviceName = u''
|
self.serviceName = u''
|
||||||
|
self.suffixes = []
|
||||||
self.droppos = 0
|
self.droppos = 0
|
||||||
#is a new service and has not been saved
|
#is a new service and has not been saved
|
||||||
self.isNew = True
|
self.isNew = True
|
||||||
@ -228,6 +229,9 @@ class ServiceManager(QtGui.QWidget):
|
|||||||
self.themeMenu = QtGui.QMenu(self.trUtf8(u'&Change Item Theme'))
|
self.themeMenu = QtGui.QMenu(self.trUtf8(u'&Change Item Theme'))
|
||||||
self.menu.addMenu(self.themeMenu)
|
self.menu.addMenu(self.themeMenu)
|
||||||
|
|
||||||
|
def supportedSuffixes(self, suffix):
|
||||||
|
self.suffixes.append(suffix)
|
||||||
|
|
||||||
def contextMenu(self, point):
|
def contextMenu(self, point):
|
||||||
item = self.ServiceManagerList.itemAt(point)
|
item = self.ServiceManagerList.itemAt(point)
|
||||||
if item is None:
|
if item is None:
|
||||||
@ -326,7 +330,7 @@ class ServiceManager(QtGui.QWidget):
|
|||||||
Called by a signal to select a specific item
|
Called by a signal to select a specific item
|
||||||
"""
|
"""
|
||||||
self.setItem(int(message[0]))
|
self.setItem(int(message[0]))
|
||||||
|
|
||||||
def setItem(self, index):
|
def setItem(self, index):
|
||||||
"""
|
"""
|
||||||
Makes a specific item in the service live
|
Makes a specific item in the service live
|
||||||
@ -495,19 +499,22 @@ class ServiceManager(QtGui.QWidget):
|
|||||||
for itemcount, item in enumerate(self.serviceItems):
|
for itemcount, item in enumerate(self.serviceItems):
|
||||||
serviceitem = item[u'service_item']
|
serviceitem = item[u'service_item']
|
||||||
treewidgetitem = QtGui.QTreeWidgetItem(self.ServiceManagerList)
|
treewidgetitem = QtGui.QTreeWidgetItem(self.ServiceManagerList)
|
||||||
if serviceitem.notes:
|
if serviceitem.isValid:
|
||||||
icon = QtGui.QImage(serviceitem.icon)
|
if serviceitem.notes:
|
||||||
icon = icon.scaled(80, 80, QtCore.Qt.KeepAspectRatio,
|
icon = QtGui.QImage(serviceitem.icon)
|
||||||
QtCore.Qt.SmoothTransformation)
|
icon = icon.scaled(80, 80, QtCore.Qt.KeepAspectRatio,
|
||||||
overlay = QtGui.QImage(':/services/service_item_notes.png')
|
QtCore.Qt.SmoothTransformation)
|
||||||
overlay = overlay.scaled(80, 80, QtCore.Qt.KeepAspectRatio,
|
overlay = QtGui.QImage(':/services/service_item_notes.png')
|
||||||
QtCore.Qt.SmoothTransformation)
|
overlay = overlay.scaled(80, 80, QtCore.Qt.KeepAspectRatio,
|
||||||
painter = QtGui.QPainter(icon)
|
QtCore.Qt.SmoothTransformation)
|
||||||
painter.drawImage(0, 0, overlay)
|
painter = QtGui.QPainter(icon)
|
||||||
painter.end()
|
painter.drawImage(0, 0, overlay)
|
||||||
treewidgetitem.setIcon(0, build_icon(icon))
|
painter.end()
|
||||||
|
treewidgetitem.setIcon(0, build_icon(icon))
|
||||||
|
else:
|
||||||
|
treewidgetitem.setIcon(0, serviceitem.iconic_representation)
|
||||||
else:
|
else:
|
||||||
treewidgetitem.setIcon(0, serviceitem.iconic_representation)
|
treewidgetitem.setIcon(0, build_icon(u':/general/general_delete.png'))
|
||||||
treewidgetitem.setText(0, serviceitem.title)
|
treewidgetitem.setText(0, serviceitem.title)
|
||||||
treewidgetitem.setToolTip(0, serviceitem.notes)
|
treewidgetitem.setToolTip(0, serviceitem.notes)
|
||||||
treewidgetitem.setData(0, QtCore.Qt.UserRole,
|
treewidgetitem.setData(0, QtCore.Qt.UserRole,
|
||||||
@ -651,8 +658,8 @@ class ServiceManager(QtGui.QWidget):
|
|||||||
serviceitem = ServiceItem()
|
serviceitem = ServiceItem()
|
||||||
serviceitem.RenderManager = self.parent.RenderManager
|
serviceitem.RenderManager = self.parent.RenderManager
|
||||||
serviceitem.set_from_service(item, self.servicePath)
|
serviceitem.set_from_service(item, self.servicePath)
|
||||||
if self.validateItem(serviceitem):
|
self.validateItem(serviceitem)
|
||||||
self.addServiceItem(serviceitem)
|
self.addServiceItem(serviceitem)
|
||||||
try:
|
try:
|
||||||
if os.path.isfile(p_file):
|
if os.path.isfile(p_file):
|
||||||
os.remove(p_file)
|
os.remove(p_file)
|
||||||
@ -671,12 +678,14 @@ class ServiceManager(QtGui.QWidget):
|
|||||||
self.parent.serviceChanged(True, self.serviceName)
|
self.parent.serviceChanged(True, self.serviceName)
|
||||||
|
|
||||||
def validateItem(self, serviceItem):
|
def validateItem(self, serviceItem):
|
||||||
# print "---"
|
"""
|
||||||
# print serviceItem.name
|
Validates the service item and if the suffix matches an accepted
|
||||||
# print serviceItem.title
|
one it allows the item to be displayed
|
||||||
# print serviceItem.service_item_path
|
"""
|
||||||
# print serviceItem.service_item_type
|
if serviceItem.is_command():
|
||||||
return True
|
type = serviceItem._raw_frames[0][u'title'].split(u'.')[1]
|
||||||
|
if type not in self.suffixes:
|
||||||
|
serviceItem.isValid = False
|
||||||
|
|
||||||
def cleanUp(self):
|
def cleanUp(self):
|
||||||
"""
|
"""
|
||||||
@ -760,8 +769,17 @@ class ServiceManager(QtGui.QWidget):
|
|||||||
Send the current item to the Preview slide controller
|
Send the current item to the Preview slide controller
|
||||||
"""
|
"""
|
||||||
item, count = self.findServiceItem()
|
item, count = self.findServiceItem()
|
||||||
self.parent.PreviewController.addServiceManagerItem(
|
if self.serviceItems[item][u'service_item'].isValid:
|
||||||
self.serviceItems[item][u'service_item'], count)
|
self.parent.PreviewController.addServiceManagerItem(
|
||||||
|
self.serviceItems[item][u'service_item'], count)
|
||||||
|
else:
|
||||||
|
QtGui.QMessageBox.critical(self,
|
||||||
|
self.trUtf8('Missing Display Handler'),
|
||||||
|
self.trUtf8('Your item cannot be displayed as '
|
||||||
|
'there is no handler to display it'),
|
||||||
|
QtGui.QMessageBox.StandardButtons(
|
||||||
|
QtGui.QMessageBox.Ok),
|
||||||
|
QtGui.QMessageBox.Ok)
|
||||||
|
|
||||||
def getServiceItem(self):
|
def getServiceItem(self):
|
||||||
"""
|
"""
|
||||||
@ -778,17 +796,26 @@ class ServiceManager(QtGui.QWidget):
|
|||||||
Send the current item to the Live slide controller
|
Send the current item to the Live slide controller
|
||||||
"""
|
"""
|
||||||
item, count = self.findServiceItem()
|
item, count = self.findServiceItem()
|
||||||
self.parent.LiveController.addServiceManagerItem(
|
if self.serviceItems[item][u'service_item'].isValid:
|
||||||
self.serviceItems[item][u'service_item'], count)
|
self.parent.LiveController.addServiceManagerItem(
|
||||||
if QtCore.QSettings().value(
|
self.serviceItems[item][u'service_item'], count)
|
||||||
self.parent.generalSettingsSection + u'/auto preview',
|
if QtCore.QSettings().value(
|
||||||
QtCore.QVariant(False)).toBool():
|
self.parent.generalSettingsSection + u'/auto preview',
|
||||||
item += 1
|
QtCore.QVariant(False)).toBool():
|
||||||
if self.serviceItems and item < len(self.serviceItems) and \
|
item += 1
|
||||||
self.serviceItems[item][u'service_item'].is_capable(
|
if self.serviceItems and item < len(self.serviceItems) and \
|
||||||
ItemCapabilities.AllowsPreview):
|
self.serviceItems[item][u'service_item'].is_capable(
|
||||||
self.parent.PreviewController.addServiceManagerItem(
|
ItemCapabilities.AllowsPreview):
|
||||||
self.serviceItems[item][u'service_item'], 0)
|
self.parent.PreviewController.addServiceManagerItem(
|
||||||
|
self.serviceItems[item][u'service_item'], 0)
|
||||||
|
else:
|
||||||
|
QtGui.QMessageBox.critical(self,
|
||||||
|
self.trUtf8('Missing Display Handler'),
|
||||||
|
self.trUtf8('Your item cannot be displayed as '
|
||||||
|
'there is no handler to display it'),
|
||||||
|
QtGui.QMessageBox.StandardButtons(
|
||||||
|
QtGui.QMessageBox.Ok),
|
||||||
|
QtGui.QMessageBox.Ok)
|
||||||
|
|
||||||
def remoteEdit(self):
|
def remoteEdit(self):
|
||||||
"""
|
"""
|
||||||
@ -920,7 +947,7 @@ class ServiceManager(QtGui.QWidget):
|
|||||||
return item.data(0, QtCore.Qt.UserRole).toInt()[0]
|
return item.data(0, QtCore.Qt.UserRole).toInt()[0]
|
||||||
else:
|
else:
|
||||||
return parentitem.data(0, QtCore.Qt.UserRole).toInt()[0]
|
return parentitem.data(0, QtCore.Qt.UserRole).toInt()[0]
|
||||||
|
|
||||||
def listRequest(self, message=None):
|
def listRequest(self, message=None):
|
||||||
data = []
|
data = []
|
||||||
curindex, count = self.findServiceItem()
|
curindex, count = self.findServiceItem()
|
||||||
|
@ -339,16 +339,16 @@ class SlideController(QtGui.QWidget):
|
|||||||
QtCore.SIGNAL(u'slidecontroller_%s_change' % self.type_prefix),
|
QtCore.SIGNAL(u'slidecontroller_%s_change' % self.type_prefix),
|
||||||
self.onSlideChange)
|
self.onSlideChange)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
QtCore.QObject.connect(Receiver.get_receiver(),
|
||||||
QtCore.SIGNAL(u'slidecontroller_%s_set' % self.type_prefix),
|
QtCore.SIGNAL(u'slidecontroller_%s_set' % self.type_prefix),
|
||||||
self.onSlideSelectedIndex)
|
self.onSlideSelectedIndex)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
QtCore.QObject.connect(Receiver.get_receiver(),
|
||||||
QtCore.SIGNAL(u'slidecontroller_%s_blank' % self.type_prefix),
|
QtCore.SIGNAL(u'slidecontroller_%s_blank' % self.type_prefix),
|
||||||
self.onSlideBlank)
|
self.onSlideBlank)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
QtCore.QObject.connect(Receiver.get_receiver(),
|
||||||
QtCore.SIGNAL(u'slidecontroller_%s_unblank' % self.type_prefix),
|
QtCore.SIGNAL(u'slidecontroller_%s_unblank' % self.type_prefix),
|
||||||
self.onSlideUnblank)
|
self.onSlideUnblank)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
QtCore.QObject.connect(Receiver.get_receiver(),
|
||||||
QtCore.SIGNAL(u'slidecontroller_%s_text_request' % self.type_prefix),
|
QtCore.SIGNAL(u'slidecontroller_%s_text_request' % self.type_prefix),
|
||||||
self.onTextRequest)
|
self.onTextRequest)
|
||||||
QtCore.QObject.connect(self.Splitter,
|
QtCore.QObject.connect(self.Splitter,
|
||||||
QtCore.SIGNAL(u'splitterMoved(int, int)'), self.trackSplitter)
|
QtCore.SIGNAL(u'splitterMoved(int, int)'), self.trackSplitter)
|
||||||
@ -486,6 +486,7 @@ class SlideController(QtGui.QWidget):
|
|||||||
Display the slide number passed
|
Display the slide number passed
|
||||||
"""
|
"""
|
||||||
log.debug(u'processManagerItem')
|
log.debug(u'processManagerItem')
|
||||||
|
self.onStopLoop()
|
||||||
#If old item was a command tell it to stop
|
#If old item was a command tell it to stop
|
||||||
if self.serviceItem and self.serviceItem.is_command():
|
if self.serviceItem and self.serviceItem.is_command():
|
||||||
self.onMediaStop()
|
self.onMediaStop()
|
||||||
@ -589,8 +590,8 @@ class SlideController(QtGui.QWidget):
|
|||||||
data_item[u'selected'] = \
|
data_item[u'selected'] = \
|
||||||
(self.PreviewListWidget.currentRow() == framenumber)
|
(self.PreviewListWidget.currentRow() == framenumber)
|
||||||
data.append(data_item)
|
data.append(data_item)
|
||||||
Receiver.send_message(u'slidecontroller_%s_text_response'
|
Receiver.send_message(u'slidecontroller_%s_text_response'
|
||||||
% self.type_prefix, data)
|
% self.type_prefix, data)
|
||||||
|
|
||||||
#Screen event methods
|
#Screen event methods
|
||||||
def onSlideSelectedFirst(self):
|
def onSlideSelectedFirst(self):
|
||||||
@ -614,7 +615,7 @@ class SlideController(QtGui.QWidget):
|
|||||||
index = int(message[0])
|
index = int(message[0])
|
||||||
if not self.serviceItem:
|
if not self.serviceItem:
|
||||||
return
|
return
|
||||||
Receiver.send_message(u'%s_slide' % self.serviceItem.name.lower(),
|
Receiver.send_message(u'%s_slide' % self.serviceItem.name.lower(),
|
||||||
[self.serviceItem, self.isLive, index])
|
[self.serviceItem, self.isLive, index])
|
||||||
if self.serviceItem.is_command():
|
if self.serviceItem.is_command():
|
||||||
self.updatePreview()
|
self.updatePreview()
|
||||||
@ -841,7 +842,9 @@ class SlideController(QtGui.QWidget):
|
|||||||
"""
|
"""
|
||||||
Stop the timer loop running
|
Stop the timer loop running
|
||||||
"""
|
"""
|
||||||
self.killTimer(self.timer_id)
|
if self.timer_id != 0:
|
||||||
|
self.killTimer(self.timer_id)
|
||||||
|
self.timer_id = 0
|
||||||
|
|
||||||
def timerEvent(self, event):
|
def timerEvent(self, event):
|
||||||
"""
|
"""
|
||||||
|
@ -58,6 +58,7 @@ class MediaPlugin(Plugin):
|
|||||||
if len(value) == 2:
|
if len(value) == 2:
|
||||||
if list.find(value[1]) == -1:
|
if list.find(value[1]) == -1:
|
||||||
list += u'*.%s ' % value[1]
|
list += u'*.%s ' % value[1]
|
||||||
|
self.service_manager.supportedSuffixes(value[1])
|
||||||
type = u''
|
type = u''
|
||||||
return list, type
|
return list, type
|
||||||
|
|
||||||
|
@ -74,6 +74,7 @@ class PresentationMediaItem(MediaManagerItem):
|
|||||||
for type in types:
|
for type in types:
|
||||||
if fileType.find(type) == -1:
|
if fileType.find(type) == -1:
|
||||||
fileType += u'*%s ' % type
|
fileType += u'*%s ' % type
|
||||||
|
self.parent.service_manager.supportedSuffixes(type)
|
||||||
self.OnNewFileMasks = self.trUtf8('Presentations (%s)' % fileType)
|
self.OnNewFileMasks = self.trUtf8('Presentations (%s)' % fileType)
|
||||||
|
|
||||||
def requiredIcons(self):
|
def requiredIcons(self):
|
||||||
|
Loading…
Reference in New Issue
Block a user