diff --git a/openlp/core/lib/projector/constants.py b/openlp/core/lib/projector/constants.py
index 72903f45f..eec17bf47 100644
--- a/openlp/core/lib/projector/constants.py
+++ b/openlp/core/lib/projector/constants.py
@@ -61,7 +61,8 @@ LF = chr(0x0A) # \n
PJLINK_PORT = 4352
TIMEOUT = 30.0
PJLINK_MAX_PACKET = 136
-PJLINK_VALID_CMD = {'1': ['POWR', # Power option
+PJLINK_VALID_CMD = {'1': ['PJLINK', # Initial connection
+ 'POWR', # Power option
'INPT', # Video sources option
'AVMT', # Shutter option
'ERST', # Error status option
diff --git a/openlp/core/lib/projector/pjlink1.py b/openlp/core/lib/projector/pjlink1.py
index e557839d6..e6d63362f 100644
--- a/openlp/core/lib/projector/pjlink1.py
+++ b/openlp/core/lib/projector/pjlink1.py
@@ -128,17 +128,7 @@ class PJLink1(QTcpSocket):
self.setReadBufferSize(self.maxSize)
# PJLink projector information
self.pjlink_class = '1' # Default class
- self.power = S_OFF
- self.pjlink_name = None
- self.manufacturer = None
- self.model = None
- self.shutter = None
- self.mute = None
- self.lamp = None
- self.fan = None
- self.source_available = None
- self.source = None
- self.projector_errors = None
+ self.reset_information()
# Set from ProjectorManager.add_projector()
self.widget = None # QListBox entry
self.timer = None # Timer that calls the poll_loop
@@ -156,6 +146,19 @@ class PJLink1(QTcpSocket):
'POWR': self.process_powr
}
+ def reset_information(self):
+ self.power = S_OFF
+ self.pjlink_name = None
+ self.manufacturer = None
+ self.model = None
+ self.shutter = None
+ self.mute = None
+ self.lamp = None
+ self.fan = None
+ self.source_available = None
+ self.source = None
+ self.projector_errors = None
+
def thread_started(self):
"""
Connects signals to methods when thread is started.
diff --git a/openlp/core/ui/projector/manager.py b/openlp/core/ui/projector/manager.py
index 6012ab693..e62a2b4f2 100644
--- a/openlp/core/ui/projector/manager.py
+++ b/openlp/core/ui/projector/manager.py
@@ -60,7 +60,8 @@ STATUS_ICONS = {S_NOT_CONNECTED: ':/projector/projector_item_disconnect.png',
E_ERROR: ':/projector/projector_error.png',
E_NETWORK: ':/projector/projector_not_connected.png',
E_AUTHENTICATION: ':/projector/projector_not_connected.png',
- E_UNKNOWN_SOCKET_ERROR: ':/icons/openlp-logo-64x64.png'
+ E_UNKNOWN_SOCKET_ERROR: ':/icons/openlp-logo-64x64.png',
+ E_NOT_CONNECTED: ':/projector/projector_not_connected.png'
}
@@ -730,10 +731,9 @@ class ProjectorManager(OpenLPMixin, RegistryMixin, QtGui.QWidget, Ui_ProjectorMa
notes = translate('OpenLP.ProjectorManager', 'Notes')
QtGui.QMessageBox.information(self, translate('OpenLP.ProjectorManager',
'Projector %s Information' % projector.link.name),
- '%s: %s
%s: %s
%s: %s
'
+ '
%s: %s
%s: %s
'
'%s: %s
%s: %s
'
- '%s:
%s' % (dbid, projector.link.dbid,
- ip, projector.link.ip,
+ '%s:
%s' % (ip, projector.link.ip,
port, projector.link.port,
name, projector.link.name,
location, projector.link.location,
@@ -890,7 +890,11 @@ class ProjectorManager(OpenLPMixin, RegistryMixin, QtGui.QWidget, Ui_ProjectorMa
log.debug('(%s) updateStatus(status=%s) message: "%s"' % (item.link.name, status_code, message))
if status in STATUS_ICONS:
item.icon = QtGui.QIcon(QtGui.QPixmap(STATUS_ICONS[status]))
- log.debug('(%s) Updating icon' % item.link.name)
+ if status in ERROR_STRING:
+ status_code = ERROR_STRING[status]
+ elif status in STATUS_STRING:
+ status_code = STATUS_STRING[status]
+ log.debug('(%s) Updating icon with %s' % (item.link.name, status_code))
item.widget.setIcon(item.icon)
@pyqtSlot()