forked from openlp/openlp
Changes to settings and SlideController handling
bzr-revno: 603
This commit is contained in:
commit
bf5c99a71f
@ -83,6 +83,9 @@ class EventReceiver(QtCore.QObject):
|
|||||||
|
|
||||||
``audit_changed``
|
``audit_changed``
|
||||||
Audit information may have changed
|
Audit information may have changed
|
||||||
|
|
||||||
|
``config_updated``
|
||||||
|
Informs components the config has changed
|
||||||
"""
|
"""
|
||||||
global log
|
global log
|
||||||
log = logging.getLogger(u'EventReceiver')
|
log = logging.getLogger(u'EventReceiver')
|
||||||
|
@ -25,9 +25,40 @@
|
|||||||
import logging
|
import logging
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Receiver
|
from openlp.core.lib import Receiver, str_to_bool
|
||||||
|
|
||||||
class MainDisplay(QtGui.QWidget):
|
class DisplayLabel(QtGui.QWidget):
|
||||||
|
"""
|
||||||
|
Customised version of QTableWidget which can respond to keyboard
|
||||||
|
events.
|
||||||
|
"""
|
||||||
|
def __init__(self, parent=None, name=None):
|
||||||
|
QQtGui.QWidget.__init__(self, parent)
|
||||||
|
self.parent = parent
|
||||||
|
|
||||||
|
def keyPressEvent(self, event):
|
||||||
|
if type(event) == QtGui.QKeyEvent:
|
||||||
|
#here accept the event and do something
|
||||||
|
if event.key() == QtCore.Qt.Key_Up:
|
||||||
|
Receiver().send_message(u'slidecontroller_previous')
|
||||||
|
event.accept()
|
||||||
|
elif event.key() == QtCore.Qt.Key_Down:
|
||||||
|
Receiver().send_message(u'slidecontroller_next')
|
||||||
|
event.accept()
|
||||||
|
elif event.key() == QtCore.Qt.Key_PageUp:
|
||||||
|
Receiver().send_message(u'slidecontroller_first')
|
||||||
|
event.accept()
|
||||||
|
elif event.key() == QtCore.Qt.Key_PageDown:
|
||||||
|
Receiver().send_message(u'slidecontroller_last')
|
||||||
|
event.accept()
|
||||||
|
elif event.key() == QtCore.Qt.Key_Escape:
|
||||||
|
self.resetDisplay()
|
||||||
|
event.accept()
|
||||||
|
event.ignore()
|
||||||
|
else:
|
||||||
|
event.ignore()
|
||||||
|
|
||||||
|
class MainDisplay(DisplayLabel):
|
||||||
"""
|
"""
|
||||||
This is the form that is used to display things on the projector.
|
This is the form that is used to display things on the projector.
|
||||||
"""
|
"""
|
||||||
@ -59,6 +90,7 @@ class MainDisplay(QtGui.QWidget):
|
|||||||
self.layout.addWidget(self.display)
|
self.layout.addWidget(self.display)
|
||||||
self.displayBlank = False
|
self.displayBlank = False
|
||||||
self.blankFrame = None
|
self.blankFrame = None
|
||||||
|
self.frame = None
|
||||||
self.alertactive = False
|
self.alertactive = False
|
||||||
self.alertTab = None
|
self.alertTab = None
|
||||||
self.timer_id = 0
|
self.timer_id = 0
|
||||||
@ -66,6 +98,10 @@ class MainDisplay(QtGui.QWidget):
|
|||||||
QtCore.SIGNAL(u'live_slide_blank'), self.blankDisplay)
|
QtCore.SIGNAL(u'live_slide_blank'), self.blankDisplay)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
QtCore.QObject.connect(Receiver.get_receiver(),
|
||||||
QtCore.SIGNAL(u'alert_text'), self.displayAlert)
|
QtCore.SIGNAL(u'alert_text'), self.displayAlert)
|
||||||
|
QtCore.QObject.connect(Receiver.get_receiver(),
|
||||||
|
QtCore.SIGNAL(u'presentations_start'), self.hideDisplay)
|
||||||
|
QtCore.QObject.connect(Receiver.get_receiver(),
|
||||||
|
QtCore.SIGNAL(u'presentations_stop'), self.showDisplay)
|
||||||
|
|
||||||
def setup(self, screenNumber):
|
def setup(self, screenNumber):
|
||||||
"""
|
"""
|
||||||
@ -84,9 +120,12 @@ class MainDisplay(QtGui.QWidget):
|
|||||||
self.setGeometry(screen[u'size'])
|
self.setGeometry(screen[u'size'])
|
||||||
if not screen[u'primary']:
|
if not screen[u'primary']:
|
||||||
self.showFullScreen()
|
self.showFullScreen()
|
||||||
|
self.primary = False
|
||||||
else:
|
else:
|
||||||
self.showMinimized()
|
self.setVisible(False)
|
||||||
|
self.primary = True
|
||||||
#Build a custom splash screen
|
#Build a custom splash screen
|
||||||
|
if str_to_bool(self.parent.generalConfig.get_config(u'show splash', u'True')):
|
||||||
self.InitialFrame = QtGui.QImage(
|
self.InitialFrame = QtGui.QImage(
|
||||||
screen[u'size'].width(), screen[u'size'].height(),
|
screen[u'size'].width(), screen[u'size'].height(),
|
||||||
QtGui.QImage.Format_ARGB32_Premultiplied)
|
QtGui.QImage.Format_ARGB32_Premultiplied)
|
||||||
@ -107,6 +146,17 @@ class MainDisplay(QtGui.QWidget):
|
|||||||
painter.begin(self.blankFrame)
|
painter.begin(self.blankFrame)
|
||||||
painter.fillRect(self.blankFrame.rect(), QtCore.Qt.black)
|
painter.fillRect(self.blankFrame.rect(), QtCore.Qt.black)
|
||||||
|
|
||||||
|
def resetDisplay(self):
|
||||||
|
if self.primary:
|
||||||
|
self.setVisible(False)
|
||||||
|
|
||||||
|
def hideDisplay(self):
|
||||||
|
self.setVisible(False)
|
||||||
|
|
||||||
|
def showDisplay(self):
|
||||||
|
if not self.primary:
|
||||||
|
self.setVisible(True)
|
||||||
|
|
||||||
def frameView(self, frame):
|
def frameView(self, frame):
|
||||||
"""
|
"""
|
||||||
Called from a slide controller to display a frame
|
Called from a slide controller to display a frame
|
||||||
@ -119,6 +169,9 @@ class MainDisplay(QtGui.QWidget):
|
|||||||
self.displayAlert()
|
self.displayAlert()
|
||||||
elif not self.displayBlank:
|
elif not self.displayBlank:
|
||||||
self.display.setPixmap(QtGui.QPixmap.fromImage(frame))
|
self.display.setPixmap(QtGui.QPixmap.fromImage(frame))
|
||||||
|
if not self.isVisible():
|
||||||
|
self.setVisible(True)
|
||||||
|
self.showFullScreen()
|
||||||
|
|
||||||
def blankDisplay(self):
|
def blankDisplay(self):
|
||||||
if not self.displayBlank:
|
if not self.displayBlank:
|
||||||
@ -126,6 +179,7 @@ class MainDisplay(QtGui.QWidget):
|
|||||||
self.display.setPixmap(QtGui.QPixmap.fromImage(self.blankFrame))
|
self.display.setPixmap(QtGui.QPixmap.fromImage(self.blankFrame))
|
||||||
else:
|
else:
|
||||||
self.displayBlank = False
|
self.displayBlank = False
|
||||||
|
if self.frame is not None:
|
||||||
self.frameView(self.frame)
|
self.frameView(self.frame)
|
||||||
|
|
||||||
def displayAlert(self, text=u''):
|
def displayAlert(self, text=u''):
|
||||||
|
@ -368,7 +368,7 @@ class Ui_MainWindow(object):
|
|||||||
self.action_Preview_Panel.setStatusTip(translate(u'mainWindow',
|
self.action_Preview_Panel.setStatusTip(translate(u'mainWindow',
|
||||||
u'Toggle the visibility of the Preview Panel'))
|
u'Toggle the visibility of the Preview Panel'))
|
||||||
self.action_Preview_Panel.setShortcut(translate(u'mainWindow', u'F11'))
|
self.action_Preview_Panel.setShortcut(translate(u'mainWindow', u'F11'))
|
||||||
self.ToolsAlertItem.setText(translate(u'mainWindow', u'Nursery &Alert'))
|
self.ToolsAlertItem.setText(translate(u'mainWindow', u'&Alert'))
|
||||||
self.ToolsAlertItem.setStatusTip(
|
self.ToolsAlertItem.setStatusTip(
|
||||||
translate(u'mainWindow', u'Show an alert message'))
|
translate(u'mainWindow', u'Show an alert message'))
|
||||||
self.ToolsAlertItem.setShortcut(translate(u'mainWindow', u'F7'))
|
self.ToolsAlertItem.setShortcut(translate(u'mainWindow', u'F7'))
|
||||||
@ -418,8 +418,8 @@ class MainWindow(QtGui.QMainWindow, Ui_MainWindow):
|
|||||||
self.screenList = screens
|
self.screenList = screens
|
||||||
self.serviceNotSaved = False
|
self.serviceNotSaved = False
|
||||||
self.settingsmanager = SettingsManager(screens)
|
self.settingsmanager = SettingsManager(screens)
|
||||||
self.mainDisplay = MainDisplay(self, screens)
|
|
||||||
self.generalConfig = PluginConfig(u'General')
|
self.generalConfig = PluginConfig(u'General')
|
||||||
|
self.mainDisplay = MainDisplay(self, screens)
|
||||||
self.alertForm = AlertForm(self)
|
self.alertForm = AlertForm(self)
|
||||||
self.aboutForm = AboutForm(self)
|
self.aboutForm = AboutForm(self)
|
||||||
self.settingsForm = SettingsForm(self.screenList, self)
|
self.settingsForm = SettingsForm(self.screenList, self)
|
||||||
|
@ -426,8 +426,10 @@ class ServiceManager(QtGui.QWidget):
|
|||||||
files retrieved from the zip file are placed in a temporary directory
|
files retrieved from the zip file are placed in a temporary directory
|
||||||
and will only be used for this service.
|
and will only be used for this service.
|
||||||
"""
|
"""
|
||||||
filename = QtGui.QFileDialog.getOpenFileName(self, u'Open Service',
|
filename = QtGui.QFileDialog.getOpenFileName(self,
|
||||||
self.config.get_last_dir(), u'Services (*.osz)')
|
translate(u'ThemeManager', u'Open Service'),
|
||||||
|
self.config.get_last_dir(),
|
||||||
|
u'Services (*.osz)')
|
||||||
filename = unicode(filename)
|
filename = unicode(filename)
|
||||||
name = filename.split(os.path.sep)
|
name = filename.split(os.path.sep)
|
||||||
if filename != u'':
|
if filename != u'':
|
||||||
|
@ -27,6 +27,7 @@ import logging
|
|||||||
from PyQt4 import QtGui
|
from PyQt4 import QtGui
|
||||||
|
|
||||||
from openlp.core.ui import GeneralTab, ThemesTab, AlertsTab
|
from openlp.core.ui import GeneralTab, ThemesTab, AlertsTab
|
||||||
|
from openlp.core.lib import Receiver
|
||||||
from settingsdialog import Ui_SettingsDialog
|
from settingsdialog import Ui_SettingsDialog
|
||||||
|
|
||||||
log = logging.getLogger(u'SettingsForm')
|
log = logging.getLogger(u'SettingsForm')
|
||||||
@ -64,6 +65,7 @@ class SettingsForm(QtGui.QDialog, Ui_SettingsDialog):
|
|||||||
def accept(self):
|
def accept(self):
|
||||||
for tab_index in range(0, self.SettingsTabWidget.count()):
|
for tab_index in range(0, self.SettingsTabWidget.count()):
|
||||||
self.SettingsTabWidget.widget(tab_index).save()
|
self.SettingsTabWidget.widget(tab_index).save()
|
||||||
|
Receiver().send_message(u'config_updated')
|
||||||
return QtGui.QDialog.accept(self)
|
return QtGui.QDialog.accept(self)
|
||||||
|
|
||||||
def postSetUp(self):
|
def postSetUp(self):
|
||||||
|
@ -195,8 +195,14 @@ class SlideController(QtGui.QWidget):
|
|||||||
Receiver().send_message(u'request_spin_delay')
|
Receiver().send_message(u'request_spin_delay')
|
||||||
if isLive:
|
if isLive:
|
||||||
self.Toolbar.makeWidgetsInvisible(self.image_list)
|
self.Toolbar.makeWidgetsInvisible(self.image_list)
|
||||||
else:
|
QtCore.QObject.connect(Receiver.get_receiver(),
|
||||||
pass
|
QtCore.SIGNAL(u'slidecontroller_first'), self.onSlideSelectedFirst)
|
||||||
|
QtCore.QObject.connect(Receiver.get_receiver(),
|
||||||
|
QtCore.SIGNAL(u'slidecontroller_next'), self.onSlideSelectedNext)
|
||||||
|
QtCore.QObject.connect(Receiver.get_receiver(),
|
||||||
|
QtCore.SIGNAL(u'slidecontroller_previous'), self.onSlideSelectedPrevious)
|
||||||
|
QtCore.QObject.connect(Receiver.get_receiver(),
|
||||||
|
QtCore.SIGNAL(u'slidecontroller_last'), self.onSlideSelectedLast)
|
||||||
|
|
||||||
def receiveSpinDelay(self, value):
|
def receiveSpinDelay(self, value):
|
||||||
self.DelaySpinBox.setValue(int(value))
|
self.DelaySpinBox.setValue(int(value))
|
||||||
@ -321,7 +327,8 @@ class SlideController(QtGui.QWidget):
|
|||||||
"""
|
"""
|
||||||
Go to the first slide.
|
Go to the first slide.
|
||||||
"""
|
"""
|
||||||
if self.commandItem.service_item_type == ServiceType.Command:
|
if self.commandItem is not None and \
|
||||||
|
self.commandItem.service_item_type == ServiceType.Command:
|
||||||
Receiver().send_message(u'%s_first'% self.commandItem.name.lower())
|
Receiver().send_message(u'%s_first'% self.commandItem.name.lower())
|
||||||
else:
|
else:
|
||||||
self.PreviewListWidget.selectRow(0)
|
self.PreviewListWidget.selectRow(0)
|
||||||
@ -331,7 +338,8 @@ class SlideController(QtGui.QWidget):
|
|||||||
"""
|
"""
|
||||||
Blank the screen.
|
Blank the screen.
|
||||||
"""
|
"""
|
||||||
if self.commandItem.service_item_type == ServiceType.Command:
|
if self.commandItem is not None and \
|
||||||
|
self.commandItem.service_item_type == ServiceType.Command:
|
||||||
if blanked:
|
if blanked:
|
||||||
Receiver().send_message(u'%s_blank'% self.commandItem.name.lower())
|
Receiver().send_message(u'%s_blank'% self.commandItem.name.lower())
|
||||||
else:
|
else:
|
||||||
@ -363,7 +371,8 @@ class SlideController(QtGui.QWidget):
|
|||||||
"""
|
"""
|
||||||
Go to the next slide.
|
Go to the next slide.
|
||||||
"""
|
"""
|
||||||
if self.commandItem.service_item_type == ServiceType.Command:
|
if self.commandItem is not None and \
|
||||||
|
self.commandItem.service_item_type == ServiceType.Command:
|
||||||
Receiver().send_message(u'%s_next'% self.commandItem.name.lower())
|
Receiver().send_message(u'%s_next'% self.commandItem.name.lower())
|
||||||
else:
|
else:
|
||||||
row = self.PreviewListWidget.currentRow() + 1
|
row = self.PreviewListWidget.currentRow() + 1
|
||||||
@ -376,7 +385,8 @@ class SlideController(QtGui.QWidget):
|
|||||||
"""
|
"""
|
||||||
Go to the previous slide.
|
Go to the previous slide.
|
||||||
"""
|
"""
|
||||||
if self.commandItem.service_item_type == ServiceType.Command:
|
if self.commandItem is not None and \
|
||||||
|
self.commandItem.service_item_type == ServiceType.Command:
|
||||||
Receiver().send_message(
|
Receiver().send_message(
|
||||||
u'%s_previous'% self.commandItem.name.lower())
|
u'%s_previous'% self.commandItem.name.lower())
|
||||||
else:
|
else:
|
||||||
@ -390,7 +400,8 @@ class SlideController(QtGui.QWidget):
|
|||||||
"""
|
"""
|
||||||
Go to the last slide.
|
Go to the last slide.
|
||||||
"""
|
"""
|
||||||
if self.commandItem.service_item_type == ServiceType.Command:
|
if self.commandItem is not None and \
|
||||||
|
self.commandItem.service_item_type == ServiceType.Command:
|
||||||
Receiver().send_message(u'%s_last'% self.commandItem.name.lower())
|
Receiver().send_message(u'%s_last'% self.commandItem.name.lower())
|
||||||
else:
|
else:
|
||||||
self.PreviewListWidget.selectRow(self.PreviewListWidget.rowCount() - 1)
|
self.PreviewListWidget.selectRow(self.PreviewListWidget.rowCount() - 1)
|
||||||
|
@ -224,13 +224,14 @@ class ThemeManager(QtGui.QWidget):
|
|||||||
zip.close()
|
zip.close()
|
||||||
|
|
||||||
def onImportTheme(self):
|
def onImportTheme(self):
|
||||||
files = QtGui.QFileDialog.getOpenFileNames(None,
|
files = QtGui.QFileDialog.getOpenFileNames(self,
|
||||||
translate(u'ThemeManager',
|
translate(u'ThemeManager', u'Select Theme Import File'),
|
||||||
u'Select Theme Import File'),
|
self.config.get_last_dir(),
|
||||||
self.path, u'Theme (*.*)')
|
u'Theme (*.*)')
|
||||||
log.info(u'New Themes %s', unicode(files))
|
log.info(u'New Themes %s', unicode(files))
|
||||||
if len(files) > 0:
|
if len(files) > 0:
|
||||||
for file in files:
|
for file in files:
|
||||||
|
self.config.set_last_dir(filename)
|
||||||
self.unzipTheme(file, self.path)
|
self.unzipTheme(file, self.path)
|
||||||
self.loadThemes()
|
self.loadThemes()
|
||||||
|
|
||||||
|
@ -41,7 +41,6 @@ class BiblesTab(SettingsTab):
|
|||||||
self.paragraph_style = True
|
self.paragraph_style = True
|
||||||
self.show_new_chapters = False
|
self.show_new_chapters = False
|
||||||
self.display_style = 0
|
self.display_style = 0
|
||||||
self.bible_search = True
|
|
||||||
SettingsTab.__init__(
|
SettingsTab.__init__(
|
||||||
self, translate(u'BiblesTab', u'Bibles'), u'Bibles')
|
self, translate(u'BiblesTab', u'Bibles'), u'Bibles')
|
||||||
|
|
||||||
@ -98,7 +97,6 @@ class BiblesTab(SettingsTab):
|
|||||||
self.LayoutStyleComboBox.addItem(QtCore.QString())
|
self.LayoutStyleComboBox.addItem(QtCore.QString())
|
||||||
self.LayoutStyleLayout.addWidget(self.LayoutStyleComboBox)
|
self.LayoutStyleLayout.addWidget(self.LayoutStyleComboBox)
|
||||||
self.VerseDisplayLayout.addWidget(self.LayoutStyleWidget, 2, 0, 1, 1)
|
self.VerseDisplayLayout.addWidget(self.LayoutStyleWidget, 2, 0, 1, 1)
|
||||||
|
|
||||||
self.BibleThemeWidget = QtGui.QWidget(self.VerseDisplayGroupBox)
|
self.BibleThemeWidget = QtGui.QWidget(self.VerseDisplayGroupBox)
|
||||||
self.BibleThemeWidget.setObjectName(u'BibleThemeWidget')
|
self.BibleThemeWidget.setObjectName(u'BibleThemeWidget')
|
||||||
self.BibleThemeLayout = QtGui.QHBoxLayout(self.BibleThemeWidget)
|
self.BibleThemeLayout = QtGui.QHBoxLayout(self.BibleThemeWidget)
|
||||||
@ -112,10 +110,13 @@ class BiblesTab(SettingsTab):
|
|||||||
self.BibleThemeComboBox.setObjectName(u'BibleThemeComboBox')
|
self.BibleThemeComboBox.setObjectName(u'BibleThemeComboBox')
|
||||||
self.BibleThemeComboBox.addItem(QtCore.QString())
|
self.BibleThemeComboBox.addItem(QtCore.QString())
|
||||||
self.BibleThemeLayout.addWidget(self.BibleThemeComboBox)
|
self.BibleThemeLayout.addWidget(self.BibleThemeComboBox)
|
||||||
self.VerseDisplayLayout.addWidget(self.BibleThemeWidget, 3, 0, 1, 1)
|
self.BibleDuelCheckBox = QtGui.QCheckBox(self.VerseDisplayGroupBox)
|
||||||
|
self.BibleDuelCheckBox.setObjectName(u'BibleDuelCheckBox')
|
||||||
|
self.VerseDisplayLayout.addWidget(self.BibleDuelCheckBox, 3, 0, 1, 1)
|
||||||
|
self.VerseDisplayLayout.addWidget(self.BibleThemeWidget, 4, 0, 1, 1)
|
||||||
self.ChangeNoteLabel = QtGui.QLabel(self.VerseDisplayGroupBox)
|
self.ChangeNoteLabel = QtGui.QLabel(self.VerseDisplayGroupBox)
|
||||||
self.ChangeNoteLabel.setObjectName(u'ChangeNoteLabel')
|
self.ChangeNoteLabel.setObjectName(u'ChangeNoteLabel')
|
||||||
self.VerseDisplayLayout.addWidget(self.ChangeNoteLabel, 4, 0, 1, 1)
|
self.VerseDisplayLayout.addWidget(self.ChangeNoteLabel, 5, 0, 1, 1)
|
||||||
self.BibleLeftLayout.addWidget(self.VerseDisplayGroupBox)
|
self.BibleLeftLayout.addWidget(self.VerseDisplayGroupBox)
|
||||||
self.BibleLeftSpacer = QtGui.QSpacerItem(40, 20,
|
self.BibleLeftSpacer = QtGui.QSpacerItem(40, 20,
|
||||||
QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding)
|
QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding)
|
||||||
@ -127,27 +128,11 @@ class BiblesTab(SettingsTab):
|
|||||||
self.BibleRightLayout.setObjectName(u'BibleRightLayout')
|
self.BibleRightLayout.setObjectName(u'BibleRightLayout')
|
||||||
self.BibleRightLayout.setSpacing(8)
|
self.BibleRightLayout.setSpacing(8)
|
||||||
self.BibleRightLayout.setMargin(0)
|
self.BibleRightLayout.setMargin(0)
|
||||||
self.BibleSearchGroupBox = QtGui.QGroupBox(self)
|
|
||||||
self.BibleSearchGroupBox.setObjectName(u'BibleSearchGroupBox')
|
|
||||||
self.BibleSearchLayout = QtGui.QVBoxLayout(self.BibleSearchGroupBox)
|
|
||||||
self.BibleSearchLayout.setObjectName(u'BibleSearchLayout')
|
|
||||||
self.BibleSearchLayout.setSpacing(8)
|
|
||||||
self.BibleSearchLayout.setMargin(8)
|
|
||||||
self.BibleSearchCheckBox = QtGui.QCheckBox(self.BibleSearchGroupBox)
|
|
||||||
self.BibleSearchCheckBox.setObjectName(u'BibleSearchCheckBox')
|
|
||||||
self.BibleSearchLayout.addWidget(self.BibleSearchCheckBox)
|
|
||||||
self.BibleRightLayout.addWidget(self.BibleSearchGroupBox)
|
|
||||||
self.BibleRightSpacer = QtGui.QSpacerItem(40, 20,
|
|
||||||
QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding)
|
|
||||||
self.BibleRightLayout.addItem(self.BibleRightSpacer)
|
|
||||||
self.BibleLayout.addWidget(self.BibleRightWidget)
|
self.BibleLayout.addWidget(self.BibleRightWidget)
|
||||||
# Signals and slots
|
# Signals and slots
|
||||||
QtCore.QObject.connect(self.NewChaptersCheckBox,
|
QtCore.QObject.connect(self.NewChaptersCheckBox,
|
||||||
QtCore.SIGNAL(u'stateChanged(int)'),
|
QtCore.SIGNAL(u'stateChanged(int)'),
|
||||||
self.onNewChaptersCheckBoxChanged)
|
self.onNewChaptersCheckBoxChanged)
|
||||||
QtCore.QObject.connect(self.BibleSearchCheckBox,
|
|
||||||
QtCore.SIGNAL(u'stateChanged(int)'),
|
|
||||||
self.onBibleSearchCheckBoxChanged)
|
|
||||||
QtCore.QObject.connect(self.DisplayStyleComboBox,
|
QtCore.QObject.connect(self.DisplayStyleComboBox,
|
||||||
QtCore.SIGNAL(u'activated(int)'),
|
QtCore.SIGNAL(u'activated(int)'),
|
||||||
self.onDisplayStyleComboBoxChanged)
|
self.onDisplayStyleComboBoxChanged)
|
||||||
@ -156,6 +141,9 @@ class BiblesTab(SettingsTab):
|
|||||||
QtCore.QObject.connect(self.LayoutStyleComboBox,
|
QtCore.QObject.connect(self.LayoutStyleComboBox,
|
||||||
QtCore.SIGNAL(u'activated(int)'),
|
QtCore.SIGNAL(u'activated(int)'),
|
||||||
self.onLayoutStyleComboBoxChanged)
|
self.onLayoutStyleComboBoxChanged)
|
||||||
|
QtCore.QObject.connect(self.BibleDuelCheckBox,
|
||||||
|
QtCore.SIGNAL(u'stateChanged(int)'),
|
||||||
|
self.onBibleDuelCheckBox)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
QtCore.QObject.connect(Receiver.get_receiver(),
|
||||||
QtCore.SIGNAL(u'update_themes'), self.updateThemeList)
|
QtCore.SIGNAL(u'update_themes'), self.updateThemeList)
|
||||||
|
|
||||||
@ -186,10 +174,8 @@ class BiblesTab(SettingsTab):
|
|||||||
3, translate(u'SettingsForm', u'[ and ]'))
|
3, translate(u'SettingsForm', u'[ and ]'))
|
||||||
self.ChangeNoteLabel.setText(translate(u'SettingsForm',
|
self.ChangeNoteLabel.setText(translate(u'SettingsForm',
|
||||||
u'Note:\nChanges don\'t affect verses already in the service'))
|
u'Note:\nChanges don\'t affect verses already in the service'))
|
||||||
self.BibleSearchGroupBox.setTitle(
|
self.BibleDuelCheckBox.setText(
|
||||||
translate(u'SettingsForm', u'Search'))
|
translate(u'SettingsForm', u'Display Duel Bible Verses'))
|
||||||
self.BibleSearchCheckBox.setText(
|
|
||||||
translate(u'SettingsForm', u'Search-as-you-type'))
|
|
||||||
|
|
||||||
def onBibleThemeComboBoxChanged(self):
|
def onBibleThemeComboBoxChanged(self):
|
||||||
self.bible_theme = self.BibleThemeComboBox.currentText()
|
self.bible_theme = self.BibleThemeComboBox.currentText()
|
||||||
@ -200,19 +186,17 @@ class BiblesTab(SettingsTab):
|
|||||||
def onLayoutStyleComboBoxChanged(self):
|
def onLayoutStyleComboBoxChanged(self):
|
||||||
self.layout_style = self.LayoutStyleComboBox.currentIndex()
|
self.layout_style = self.LayoutStyleComboBox.currentIndex()
|
||||||
|
|
||||||
def onNewChaptersCheckBoxChanged(self):
|
def onNewChaptersCheckBoxChanged(self, check_state):
|
||||||
check_state = self.NewChaptersCheckBox.checkState()
|
|
||||||
self.show_new_chapters = False
|
self.show_new_chapters = False
|
||||||
# we have a set value convert to True/False
|
# we have a set value convert to True/False
|
||||||
if check_state == QtCore.Qt.Checked:
|
if check_state == QtCore.Qt.Checked:
|
||||||
self.show_new_chapters = True
|
self.show_new_chapters = True
|
||||||
|
|
||||||
def onBibleSearchCheckBoxChanged(self):
|
def onBibleDuelCheckBox(self, check_state):
|
||||||
check_state = self.BibleSearchCheckBox.checkState()
|
self.duel_bibles = False
|
||||||
self.bible_search = False
|
|
||||||
# we have a set value convert to True/False
|
# we have a set value convert to True/False
|
||||||
if check_state == QtCore.Qt.Checked:
|
if check_state == QtCore.Qt.Checked:
|
||||||
self.bible_search = True
|
self.duel_bibles = True
|
||||||
|
|
||||||
def load(self):
|
def load(self):
|
||||||
self.show_new_chapters = str_to_bool(
|
self.show_new_chapters = str_to_bool(
|
||||||
@ -222,12 +206,12 @@ class BiblesTab(SettingsTab):
|
|||||||
self.layout_style = int(
|
self.layout_style = int(
|
||||||
self.config.get_config(u'verse layout style', u'0'))
|
self.config.get_config(u'verse layout style', u'0'))
|
||||||
self.bible_theme = self.config.get_config(u'bible theme', u'0')
|
self.bible_theme = self.config.get_config(u'bible theme', u'0')
|
||||||
self.bible_search = str_to_bool(
|
self.duel_bibles = str_to_bool(
|
||||||
self.config.get_config(u'search as type', u'True'))
|
self.config.get_config(u'duel bibles', u'True'))
|
||||||
self.NewChaptersCheckBox.setChecked(self.show_new_chapters)
|
self.NewChaptersCheckBox.setChecked(self.show_new_chapters)
|
||||||
self.DisplayStyleComboBox.setCurrentIndex(self.display_style)
|
self.DisplayStyleComboBox.setCurrentIndex(self.display_style)
|
||||||
self.LayoutStyleComboBox.setCurrentIndex(self.layout_style)
|
self.LayoutStyleComboBox.setCurrentIndex(self.layout_style)
|
||||||
self.BibleSearchCheckBox.setChecked(self.bible_search)
|
self.BibleDuelCheckBox.setChecked(self.duel_bibles)
|
||||||
|
|
||||||
def save(self):
|
def save(self):
|
||||||
self.config.set_config(
|
self.config.set_config(
|
||||||
@ -236,7 +220,7 @@ class BiblesTab(SettingsTab):
|
|||||||
u'display brackets', unicode(self.display_style))
|
u'display brackets', unicode(self.display_style))
|
||||||
self.config.set_config(
|
self.config.set_config(
|
||||||
u'verse layout style', unicode(self.layout_style))
|
u'verse layout style', unicode(self.layout_style))
|
||||||
self.config.set_config(u'search as type', unicode(self.bible_search))
|
self.config.set_config(u'duel bibles', unicode(self.duel_bibles))
|
||||||
self.config.set_config(u'bible theme', unicode(self.bible_theme))
|
self.config.set_config(u'bible theme', unicode(self.bible_theme))
|
||||||
|
|
||||||
def updateThemeList(self, theme_list):
|
def updateThemeList(self, theme_list):
|
||||||
|
@ -28,7 +28,7 @@ import time
|
|||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import translate, MediaManagerItem, Receiver, \
|
from openlp.core.lib import translate, MediaManagerItem, Receiver, \
|
||||||
BaseListWithDnD
|
BaseListWithDnD, str_to_bool
|
||||||
from openlp.plugins.bibles.forms import BibleImportForm
|
from openlp.plugins.bibles.forms import BibleImportForm
|
||||||
from openlp.plugins.bibles.lib.manager import BibleMode
|
from openlp.plugins.bibles.lib.manager import BibleMode
|
||||||
|
|
||||||
@ -203,6 +203,17 @@ class BibleMediaItem(MediaManagerItem):
|
|||||||
QtCore.SIGNAL(u'pressed()'), self.onAdvancedSearchButton)
|
QtCore.SIGNAL(u'pressed()'), self.onAdvancedSearchButton)
|
||||||
QtCore.QObject.connect(self.QuickSearchButton,
|
QtCore.QObject.connect(self.QuickSearchButton,
|
||||||
QtCore.SIGNAL(u'pressed()'), self.onQuickSearchButton)
|
QtCore.SIGNAL(u'pressed()'), self.onQuickSearchButton)
|
||||||
|
QtCore.QObject.connect(Receiver.get_receiver(),
|
||||||
|
QtCore.SIGNAL(u'config_updated'), self.configUpdated)
|
||||||
|
|
||||||
|
def configUpdated(self):
|
||||||
|
if str_to_bool(
|
||||||
|
self.parent.config.get_config(u'duel bibles', u'False')):
|
||||||
|
self.AdvancedSecondBibleComboBox.setVisible(True)
|
||||||
|
self.QuickSecondBibleComboBox.setVisible(True)
|
||||||
|
else:
|
||||||
|
self.AdvancedSecondBibleComboBox.setVisible(False)
|
||||||
|
self.QuickSecondBibleComboBox.setVisible(False)
|
||||||
|
|
||||||
def retranslateUi(self):
|
def retranslateUi(self):
|
||||||
log.debug(u'retranslateUi')
|
log.debug(u'retranslateUi')
|
||||||
@ -242,6 +253,7 @@ class BibleMediaItem(MediaManagerItem):
|
|||||||
log.debug(u'bible manager initialise')
|
log.debug(u'bible manager initialise')
|
||||||
self.loadBibles()
|
self.loadBibles()
|
||||||
self.parent.biblemanager.set_media_manager(self)
|
self.parent.biblemanager.set_media_manager(self)
|
||||||
|
self.configUpdated()
|
||||||
log.debug(u'bible manager initialise complete')
|
log.debug(u'bible manager initialise complete')
|
||||||
|
|
||||||
def setQuickMessage(self, text):
|
def setQuickMessage(self, text):
|
||||||
|
@ -27,7 +27,7 @@ import logging
|
|||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import MediaManagerItem, translate, SongXMLParser, \
|
from openlp.core.lib import MediaManagerItem, translate, SongXMLParser, \
|
||||||
BaseListWithDnD, Receiver
|
BaseListWithDnD, Receiver, str_to_bool
|
||||||
from openlp.plugins.songs.forms import EditSongForm, SongMaintenanceForm
|
from openlp.plugins.songs.forms import EditSongForm, SongMaintenanceForm
|
||||||
|
|
||||||
class SongListView(BaseListWithDnD):
|
class SongListView(BaseListWithDnD):
|
||||||
@ -113,6 +113,12 @@ class SongMediaItem(MediaManagerItem):
|
|||||||
self.onSearchTextEditChanged)
|
self.onSearchTextEditChanged)
|
||||||
QtCore.QObject.connect(Receiver.get_receiver(),
|
QtCore.QObject.connect(Receiver.get_receiver(),
|
||||||
QtCore.SIGNAL(u'load_song_list'), self.onSearchTextButtonClick)
|
QtCore.SIGNAL(u'load_song_list'), self.onSearchTextButtonClick)
|
||||||
|
QtCore.QObject.connect(Receiver.get_receiver(),
|
||||||
|
QtCore.SIGNAL(u'config_updated'), self.configUpdated)
|
||||||
|
|
||||||
|
def configUpdated(self):
|
||||||
|
self.searchAsYouType = str_to_bool(
|
||||||
|
self.parent.config.get_config(u'search as type', u'False'))
|
||||||
|
|
||||||
def retranslateUi(self):
|
def retranslateUi(self):
|
||||||
self.SearchTypeLabel.setText(
|
self.SearchTypeLabel.setText(
|
||||||
@ -126,6 +132,7 @@ class SongMediaItem(MediaManagerItem):
|
|||||||
self.SearchTypeComboBox.addItem(translate(u'SongMediaItem', u'Titles'))
|
self.SearchTypeComboBox.addItem(translate(u'SongMediaItem', u'Titles'))
|
||||||
self.SearchTypeComboBox.addItem(translate(u'SongMediaItem', u'Lyrics'))
|
self.SearchTypeComboBox.addItem(translate(u'SongMediaItem', u'Lyrics'))
|
||||||
self.SearchTypeComboBox.addItem(translate(u'SongMediaItem', u'Authors'))
|
self.SearchTypeComboBox.addItem(translate(u'SongMediaItem', u'Authors'))
|
||||||
|
self.configUpdated()
|
||||||
|
|
||||||
def onSearchTextButtonClick(self):
|
def onSearchTextButtonClick(self):
|
||||||
search_keywords = unicode(self.SearchTextEdit.displayText())
|
search_keywords = unicode(self.SearchTextEdit.displayText())
|
||||||
@ -181,6 +188,7 @@ class SongMediaItem(MediaManagerItem):
|
|||||||
self.SearchTextEdit.clear()
|
self.SearchTextEdit.clear()
|
||||||
|
|
||||||
def onSearchTextEditChanged(self, text):
|
def onSearchTextEditChanged(self, text):
|
||||||
|
if self.searchAsYouType:
|
||||||
search_length = 1
|
search_length = 1
|
||||||
if self.SearchTypeComboBox.currentIndex() == 1:
|
if self.SearchTypeComboBox.currentIndex() == 1:
|
||||||
search_length = 7
|
search_length = 7
|
||||||
|
@ -22,14 +22,51 @@
|
|||||||
# Temple Place, Suite 330, Boston, MA 02111-1307 USA #
|
# Temple Place, Suite 330, Boston, MA 02111-1307 USA #
|
||||||
###############################################################################
|
###############################################################################
|
||||||
|
|
||||||
from openlp.core.lib import SettingsTab, translate
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
|
from openlp.core.lib import SettingsTab, str_to_bool, translate
|
||||||
|
|
||||||
class SongsTab(SettingsTab):
|
class SongsTab(SettingsTab):
|
||||||
"""
|
"""
|
||||||
SongsTab is the songs settings tab in the settings dialog.
|
SongsTab is the Songs settings tab in the settings dialog.
|
||||||
"""
|
"""
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
SettingsTab.__init__(self, translate(u'SongsTab', u'Songs'), u'Songs')
|
SettingsTab.__init__(self, translate(u'SongsTab', u'Songs'), u'Songs')
|
||||||
|
|
||||||
def setupUi(self):
|
def setupUi(self):
|
||||||
self.setObjectName(u'SongsTab')
|
self.setObjectName(u'SongsTab')
|
||||||
|
self.SongsLayout = QtGui.QFormLayout(self)
|
||||||
|
self.SongsLayout.setObjectName(u'SongsLayout')
|
||||||
|
self.SongsModeGroupBox = QtGui.QGroupBox(self)
|
||||||
|
self.SongsModeGroupBox.setObjectName(u'SongsModeGroupBox')
|
||||||
|
self.SongsModeLayout = QtGui.QVBoxLayout(self.SongsModeGroupBox)
|
||||||
|
self.SongsModeLayout.setSpacing(8)
|
||||||
|
self.SongsModeLayout.setMargin(8)
|
||||||
|
self.SongsModeLayout.setObjectName(u'SongsModeLayout')
|
||||||
|
self.SearchAsTypeCheckBox = QtGui.QCheckBox(self.SongsModeGroupBox)
|
||||||
|
self.SearchAsTypeCheckBox.setObjectName(u'SearchAsTypeCheckBox')
|
||||||
|
self.SongsModeLayout.addWidget(self.SearchAsTypeCheckBox)
|
||||||
|
self.SongsLayout.setWidget(
|
||||||
|
0, QtGui.QFormLayout.LabelRole, self.SongsModeGroupBox)
|
||||||
|
QtCore.QObject.connect(self.SearchAsTypeCheckBox,
|
||||||
|
QtCore.SIGNAL(u'stateChanged(int)'),
|
||||||
|
self.onSearchAsTypeCheckBoxChanged)
|
||||||
|
|
||||||
|
def retranslateUi(self):
|
||||||
|
self.SongsModeGroupBox.setTitle(translate(u'SongsTab', u'Songs Mode'))
|
||||||
|
self.SearchAsTypeCheckBox.setText(
|
||||||
|
translate(u'SongsTab', u'Enable search as you type:'))
|
||||||
|
|
||||||
|
def onSearchAsTypeCheckBoxChanged(self, check_state):
|
||||||
|
self.bible_search = False
|
||||||
|
# we have a set value convert to True/False
|
||||||
|
if check_state == QtCore.Qt.Checked:
|
||||||
|
self.bible_search = True
|
||||||
|
|
||||||
|
def load(self):
|
||||||
|
self.bible_search = str_to_bool(
|
||||||
|
self.config.get_config(u'search as type', u'False'))
|
||||||
|
self.SearchAsTypeCheckBox.setChecked(self.bible_search)
|
||||||
|
|
||||||
|
def save(self):
|
||||||
|
self.config.set_config(u'search as type', unicode(self.bible_search))
|
||||||
|
@ -27,7 +27,7 @@ import logging
|
|||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import Plugin, translate, buildIcon
|
from openlp.core.lib import Plugin, translate, buildIcon
|
||||||
from openlp.plugins.songs.lib import SongManager, SongMediaItem
|
from openlp.plugins.songs.lib import SongManager, SongMediaItem, SongsTab
|
||||||
from openlp.plugins.songs.forms import OpenLPImportForm, OpenSongExportForm, \
|
from openlp.plugins.songs.forms import OpenLPImportForm, OpenSongExportForm, \
|
||||||
OpenSongImportForm, OpenLPExportForm
|
OpenSongImportForm, OpenLPExportForm
|
||||||
|
|
||||||
@ -62,6 +62,9 @@ class SongsPlugin(Plugin):
|
|||||||
def can_be_disabled(self):
|
def can_be_disabled(self):
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
def get_settings_tab(self):
|
||||||
|
return SongsTab()
|
||||||
|
|
||||||
def initialise(self):
|
def initialise(self):
|
||||||
log.info(u'Songs Initialising')
|
log.info(u'Songs Initialising')
|
||||||
#if self.songmanager is None:
|
#if self.songmanager is None:
|
||||||
|
Loading…
Reference in New Issue
Block a user