From de8d0f4d9ccf0df7a8854b273cd849cdb71b8e0e Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Tue, 16 Mar 2010 20:22:28 +0000 Subject: [PATCH 01/30] Add add to existing service item --- openlp/core/lib/mediamanageritem.py | 22 ++++++++++++++++++++++ openlp/core/ui/servicemanager.py | 10 ++++++++++ openlp/plugins/images/lib/mediaitem.py | 1 + 3 files changed, 33 insertions(+) diff --git a/openlp/core/lib/mediamanageritem.py b/openlp/core/lib/mediamanageritem.py index fd6d37ca6..241a534f7 100644 --- a/openlp/core/lib/mediamanageritem.py +++ b/openlp/core/lib/mediamanageritem.py @@ -114,6 +114,7 @@ class MediaManagerItem(QtGui.QWidget): self.Toolbar = None self.remoteTriggered = None self.ServiceItemIconName = None + self.addToServiceItem = True self.PageLayout = QtGui.QVBoxLayout(self) self.PageLayout.setSpacing(0) self.PageLayout.setContentsMargins(4, 0, 4, 0) @@ -285,6 +286,11 @@ class MediaManagerItem(QtGui.QWidget): contextMenuAction( self.ListView, u':/system/system_add.png', self.trUtf8('&Add to Service'), self.onAddClick)) + if self.addToServiceItem: + self.ListView.addAction( + contextMenuAction( + self.ListView, u':/system/system_add.png', + self.trUtf8('&Add to Service Item'), self.onAddEditClick)) QtCore.QObject.connect( self.ListView, QtCore.SIGNAL(u'doubleClicked(QModelIndex)'), self.onPreviewClick) @@ -386,6 +392,22 @@ class MediaManagerItem(QtGui.QWidget): service_item.fromPlugin = False self.parent.service_manager.addServiceItem(service_item) + def onAddEditClick(self): + if not self.ListView.selectedIndexes() and not self.remoteTriggered: + QtGui.QMessageBox.information(self, + self.trUtf8('No items selected...'), + self.trUtf8('You must select one or more items')) + else: + log.debug(self.PluginNameShort + u' Add requested') + service_item = self.parent.service_manager.getServiceItem() + if not service_item: + QtGui.QMessageBox.information(self, + self.trUtf8('No Servive item selected'), + self.trUtf8('You must select a existing Service Item to add to.')) + else: + self.generateSlideData(service_item) + self.parent.service_manager.addServiceItem(service_item) + def buildServiceItem(self): """ Common method for generating a service item diff --git a/openlp/core/ui/servicemanager.py b/openlp/core/ui/servicemanager.py index cec14fc8c..98336c2f5 100644 --- a/openlp/core/ui/servicemanager.py +++ b/openlp/core/ui/servicemanager.py @@ -666,6 +666,16 @@ class ServiceManager(QtGui.QWidget): self.parent.PreviewController.addServiceManagerItem( self.serviceItems[item][u'service_item'], count) + def getServiceItem(self): + """ + Send the current item to the Preview slide controller + """ + item, count = self.findServiceItem() + if item == -1: + return False + else: + self.remoteEditTriggered = True + return self.serviceItems[item][u'service_item'] def makeLive(self): """ diff --git a/openlp/plugins/images/lib/mediaitem.py b/openlp/plugins/images/lib/mediaitem.py index 1542faa1e..3a7fd7fd8 100644 --- a/openlp/plugins/images/lib/mediaitem.py +++ b/openlp/plugins/images/lib/mediaitem.py @@ -52,6 +52,7 @@ class ImageMediaItem(MediaManagerItem): # be instanced by the base MediaManagerItem self.ListViewWithDnD_class = ImageListView self.servicePath = None + self.addToServiceItem = True MediaManagerItem.__init__(self, parent, icon, title) self.overrideActive = False From c1182aa9cc6cf294ffda521e563af5a920ffb29d Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Tue, 16 Mar 2010 20:30:33 +0000 Subject: [PATCH 02/30] Add maintain menu item --- openlp/core/lib/serviceitem.py | 1 + openlp/core/ui/servicemanager.py | 5 +++++ openlp/plugins/images/lib/mediaitem.py | 1 + 3 files changed, 7 insertions(+) diff --git a/openlp/core/lib/serviceitem.py b/openlp/core/lib/serviceitem.py index 7d869a610..9164f3235 100644 --- a/openlp/core/lib/serviceitem.py +++ b/openlp/core/lib/serviceitem.py @@ -69,6 +69,7 @@ class ServiceItem(object): self.service_item_path = None self.service_item_type = None self.edit_enabled = False + self.maintain_allowed = False self._raw_frames = [] self._display_frames = [] self._uuid = unicode(uuid.uuid1()) diff --git a/openlp/core/ui/servicemanager.py b/openlp/core/ui/servicemanager.py index 98336c2f5..fff903648 100644 --- a/openlp/core/ui/servicemanager.py +++ b/openlp/core/ui/servicemanager.py @@ -202,6 +202,8 @@ class ServiceManager(QtGui.QWidget): self.menu = QtGui.QMenu() self.editAction = self.menu.addAction(self.trUtf8('&Edit Item')) self.editAction.setIcon(build_icon(u':/services/service_edit.png')) + self.maintainAction = self.menu.addAction(self.trUtf8('&Maintain Item')) + self.maintainAction.setIcon(build_icon(u':/services/service_edit.png')) self.notesAction = self.menu.addAction(self.trUtf8('&Notes')) self.notesAction.setIcon(build_icon(u':/services/service_notes.png')) self.deleteAction = self.menu.addAction(self.trUtf8('&Delete From Service')) @@ -227,9 +229,12 @@ class ServiceManager(QtGui.QWidget): pos = item.parent().data(0, QtCore.Qt.UserRole).toInt()[0] serviceItem = self.serviceItems[pos - 1] self.editAction.setVisible(False) + self.maintainAction.setVisible(False) self.notesAction.setVisible(False) if serviceItem[u'service_item'].edit_enabled: self.editAction.setVisible(True) + if serviceItem[u'service_item'].maintain_allowed: + self.maintainAction.setVisible(True) if item.parent() is None: self.notesAction.setVisible(True) self.themeMenu.menuAction().setVisible(False) diff --git a/openlp/plugins/images/lib/mediaitem.py b/openlp/plugins/images/lib/mediaitem.py index 3a7fd7fd8..f774efdd7 100644 --- a/openlp/plugins/images/lib/mediaitem.py +++ b/openlp/plugins/images/lib/mediaitem.py @@ -146,6 +146,7 @@ class ImageMediaItem(MediaManagerItem): if items: service_item.title = self.trUtf8('Image(s)') service_item.autoPreviewAllowed = True + service_item.maintain_allowed = True for item in items: bitem = self.ListView.item(item.row()) filename = unicode((bitem.data(QtCore.Qt.UserRole)).toString()) From 60a3468edb3f6dbfab5eb70e4189af42e1e44749 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Tue, 16 Mar 2010 21:03:10 +0000 Subject: [PATCH 03/30] remove alert dialog --- openlp/plugins/alerts/alertsplugin.py | 3 +- openlp/plugins/alerts/forms/__init__.py | 1 - .../plugins/alerts/forms/alerteditdialog.py | 67 ------- openlp/plugins/alerts/forms/alerteditform.py | 166 ------------------ 4 files changed, 1 insertion(+), 236 deletions(-) delete mode 100644 openlp/plugins/alerts/forms/alerteditdialog.py delete mode 100644 openlp/plugins/alerts/forms/alerteditform.py diff --git a/openlp/plugins/alerts/alertsplugin.py b/openlp/plugins/alerts/alertsplugin.py index 90e7946c7..4fade5f85 100644 --- a/openlp/plugins/alerts/alertsplugin.py +++ b/openlp/plugins/alerts/alertsplugin.py @@ -29,7 +29,7 @@ from PyQt4 import QtCore, QtGui from openlp.core.lib import Plugin, build_icon, PluginStatus from openlp.plugins.alerts.lib import AlertsManager, DBManager -from openlp.plugins.alerts.forms import AlertsTab, AlertForm, AlertEditForm +from openlp.plugins.alerts.forms import AlertsTab, AlertForm log = logging.getLogger(__name__) @@ -43,7 +43,6 @@ class alertsPlugin(Plugin): self.alertsmanager = AlertsManager(self) self.manager = DBManager(self.config) self.alertForm = AlertForm(self.manager, self) - self.alertEditForm = AlertEditForm(self.manager, self) self.status = PluginStatus.Active def get_settings_tab(self): diff --git a/openlp/plugins/alerts/forms/__init__.py b/openlp/plugins/alerts/forms/__init__.py index 14c30d73b..dba3abc93 100644 --- a/openlp/plugins/alerts/forms/__init__.py +++ b/openlp/plugins/alerts/forms/__init__.py @@ -25,4 +25,3 @@ from alertstab import AlertsTab from alertform import AlertForm -from alerteditform import AlertEditForm diff --git a/openlp/plugins/alerts/forms/alerteditdialog.py b/openlp/plugins/alerts/forms/alerteditdialog.py deleted file mode 100644 index 6cf4769ef..000000000 --- a/openlp/plugins/alerts/forms/alerteditdialog.py +++ /dev/null @@ -1,67 +0,0 @@ -# -*- coding: utf-8 -*- - -# Form implementation generated from reading ui file 'alerteditdialog.ui' -# -# Created: Sun Feb 14 16:45:10 2010 -# by: PyQt4 UI code generator 4.6.2 -# -# WARNING! All changes made in this file will be lost! - -from PyQt4 import QtCore, QtGui - -class Ui_AlertEditDialog(object): - def setupUi(self, AlertEditDialog): - AlertEditDialog.setObjectName(u'AlertEditDialog') - AlertEditDialog.resize(400, 300) - self.buttonBox = QtGui.QDialogButtonBox(AlertEditDialog) - self.buttonBox.setGeometry(QtCore.QRect(220, 270, 173, 27)) - self.buttonBox.setStandardButtons(QtGui.QDialogButtonBox.Cancel) - self.buttonBox.setObjectName(u'buttonBox') - self.layoutWidget = QtGui.QWidget(AlertEditDialog) - self.layoutWidget.setGeometry(QtCore.QRect(20, 10, 361, 251)) - self.layoutWidget.setObjectName(u'layoutWidget') - self.verticalLayout_2 = QtGui.QVBoxLayout(self.layoutWidget) - self.verticalLayout_2.setObjectName(u'verticalLayout_2') - self.horizontalLayout_2 = QtGui.QHBoxLayout() - self.horizontalLayout_2.setObjectName(u'horizontalLayout_2') - self.AlertLineEdit = QtGui.QLineEdit(self.layoutWidget) - self.AlertLineEdit.setObjectName(u'AlertLineEdit') - self.horizontalLayout_2.addWidget(self.AlertLineEdit) - self.verticalLayout_2.addLayout(self.horizontalLayout_2) - self.horizontalLayout = QtGui.QHBoxLayout() - self.horizontalLayout.setObjectName(u'horizontalLayout') - self.AlertListWidget = QtGui.QListWidget(self.layoutWidget) - self.AlertListWidget.setAlternatingRowColors(True) - self.AlertListWidget.setObjectName(u'AlertListWidget') - self.horizontalLayout.addWidget(self.AlertListWidget) - self.verticalLayout = QtGui.QVBoxLayout() - self.verticalLayout.setObjectName(u'verticalLayout') - self.SaveButton = QtGui.QPushButton(self.layoutWidget) - self.SaveButton.setObjectName(u'SaveButton') - self.verticalLayout.addWidget(self.SaveButton) - self.ClearButton = QtGui.QPushButton(self.layoutWidget) - self.ClearButton.setObjectName(u'ClearButton') - self.verticalLayout.addWidget(self.ClearButton) - self.AddButton = QtGui.QPushButton(self.layoutWidget) - self.AddButton.setObjectName(u'AddButton') - self.verticalLayout.addWidget(self.AddButton) - self.EditButton = QtGui.QPushButton(self.layoutWidget) - self.EditButton.setObjectName(u'EditButton') - self.verticalLayout.addWidget(self.EditButton) - self.DeleteButton = QtGui.QPushButton(self.layoutWidget) - self.DeleteButton.setObjectName(u'DeleteButton') - self.verticalLayout.addWidget(self.DeleteButton) - self.horizontalLayout.addLayout(self.verticalLayout) - self.verticalLayout_2.addLayout(self.horizontalLayout) - - self.retranslateUi(AlertEditDialog) - QtCore.QMetaObject.connectSlotsByName(AlertEditDialog) - - def retranslateUi(self, AlertEditDialog): - AlertEditDialog.setWindowTitle(self.trUtf8('Maintain Alerts')) - self.SaveButton.setText(self.trUtf8('Save')) - self.ClearButton.setText(self.trUtf8('Clear')) - self.AddButton.setText(self.trUtf8('Add')) - self.EditButton.setText(self.trUtf8('Edit')) - self.DeleteButton.setText(self.trUtf8('Delete')) - diff --git a/openlp/plugins/alerts/forms/alerteditform.py b/openlp/plugins/alerts/forms/alerteditform.py deleted file mode 100644 index a88eff4f3..000000000 --- a/openlp/plugins/alerts/forms/alerteditform.py +++ /dev/null @@ -1,166 +0,0 @@ -# -*- coding: utf-8 -*- -# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4 - -############################################################################### -# OpenLP - Open Source Lyrics Projection # -# --------------------------------------------------------------------------- # -# Copyright (c) 2008-2010 Raoul Snyman # -# Portions copyright (c) 2008-2010 Tim Bentley, Jonathan Corwin, Michael # -# Gorven, Scott Guerrieri, Maikel Stuivenberg, Martin Thompson, Jon Tibble, # -# Carsten Tinggaard # -# --------------------------------------------------------------------------- # -# 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 PyQt4 import QtGui, QtCore -from openlp.plugins.alerts.lib.models import AlertItem - -from alerteditdialog import Ui_AlertEditDialog - -class AlertEditForm(QtGui.QDialog, Ui_AlertEditDialog): - """ - Class documentation goes here. - """ - def __init__(self, manager, parent): - """ - Constructor - """ - self.manager = manager - self.parent = parent - QtGui.QDialog.__init__(self, None) - self.setupUi(self) - QtCore.QObject.connect(self.DeleteButton, - QtCore.SIGNAL(u'clicked()'), - self.onDeleteClick) - QtCore.QObject.connect(self.ClearButton, - QtCore.SIGNAL(u'clicked()'), - self.onClearClick) - QtCore.QObject.connect(self.EditButton, - QtCore.SIGNAL(u'clicked()'), - self.onEditClick) - QtCore.QObject.connect(self.AddButton, - QtCore.SIGNAL(u'clicked()'), - self.onAddClick) - QtCore.QObject.connect(self.SaveButton, - QtCore.SIGNAL(u'clicked()'), - self.onSaveClick) - QtCore.QObject.connect(self.buttonBox, - QtCore.SIGNAL(u'rejected()'), self.close) - QtCore.QObject.connect(self.AlertLineEdit, - QtCore.SIGNAL(u'textChanged(const QString&)'), - self.onTextChanged) - QtCore.QObject.connect(self.AlertListWidget, - QtCore.SIGNAL(u'doubleClicked(QModelIndex)'), - self.onItemSelected) - QtCore.QObject.connect(self.AlertListWidget, - QtCore.SIGNAL(u'clicked(QModelIndex)'), - self.onItemSelected) - - def loadList(self): - self.AlertListWidget.clear() - alerts = self.manager.get_all_alerts() - for alert in alerts: - item_name = QtGui.QListWidgetItem(alert.text) - item_name.setData( - QtCore.Qt.UserRole, QtCore.QVariant(alert.id)) - self.AlertListWidget.addItem(item_name) - self.AddButton.setEnabled(True) - self.ClearButton.setEnabled(False) - self.SaveButton.setEnabled(False) - self.EditButton.setEnabled(False) - self.DeleteButton.setEnabled(False) - - def onItemSelected(self): - if self.AlertLineEdit.text(): - QtGui.QMessageBox.information(self, - self.trUtf8('Item selected to Edit'), - self.trUtf8('Please save or clear selected item')) - else: - self.EditButton.setEnabled(True) - self.DeleteButton.setEnabled(True) - - def onDeleteClick(self): - item = self.AlertListWidget.currentItem() - if item: - item_id = (item.data(QtCore.Qt.UserRole)).toInt()[0] - self.parent.manager.delete_alert(item_id) - row = self.AlertListWidget.row(item) - self.AlertListWidget.takeItem(row) - self.AddButton.setEnabled(True) - self.SaveButton.setEnabled(False) - self.DeleteButton.setEnabled(False) - self.EditButton.setEnabled(False) - - def onEditClick(self): - item = self.AlertListWidget.currentItem() - if item: - self.item_id = (item.data(QtCore.Qt.UserRole)).toInt()[0] - self.AlertLineEdit.setText(unicode(item.text())) - self.AddButton.setEnabled(True) - self.ClearButton.setEnabled(True) - self.SaveButton.setEnabled(True) - self.DeleteButton.setEnabled(True) - self.EditButton.setEnabled(False) - - def onClearClick(self): - self.AlertLineEdit.setText(u'') - self.AddButton.setEnabled(False) - self.ClearButton.setEnabled(True) - self.SaveButton.setEnabled(False) - self.DeleteButton.setEnabled(False) - self.EditButton.setEnabled(False) - - def onAddClick(self): - if len(self.AlertLineEdit.text()) == 0: - QtGui.QMessageBox.information(self, - self.trUtf8('Item selected to Add'), - self.trUtf8('Missing data')) - else: - alert = AlertItem() - alert.text = unicode(self.AlertLineEdit.text()) - self.manager.save_alert(alert) - self.onClearClick() - self.loadList() - - def onSaveClick(self): - alert = self.manager.get_alert(self.item_id) - alert.text = unicode(self.AlertLineEdit.text()) - self.manager.save_alert(alert) - self.onClearClick() - self.loadList() - - def onTextChanged(self): - self.AddButton.setEnabled(True) - - def onDoubleClick(self): - """ - List item has been double clicked to display it - """ - items = self.AlertListWidget.selectedIndexes() - for item in items: - bitem = self.AlertListWidget.item(item.row()) - self.triggerAlert(bitem.text()) - - def onSingleClick(self): - """ - List item has been single clicked to add it to - the edit field so it can be changed. - """ - items = self.AlertListWidget.selectedIndexes() - for item in items: - bitem = self.AlertListWidget.item(item.row()) - self.AlertEntryEditItem.setText(bitem.text()) - - def triggerAlert(self, text): - self.parent.alertsmanager.displayAlert(text) From 13608bedae2c2a1ee891d2a4ec8d52da38f34ac5 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Wed, 17 Mar 2010 19:04:39 +0000 Subject: [PATCH 04/30] Alter form removal complete --- openlp/plugins/alerts/alertsplugin.py | 4 - openlp/plugins/alerts/forms/alertstab.py | 156 +++++++++++++++++++---- 2 files changed, 134 insertions(+), 26 deletions(-) diff --git a/openlp/plugins/alerts/alertsplugin.py b/openlp/plugins/alerts/alertsplugin.py index 4fade5f85..0416167c6 100644 --- a/openlp/plugins/alerts/alertsplugin.py +++ b/openlp/plugins/alerts/alertsplugin.py @@ -89,10 +89,6 @@ class alertsPlugin(Plugin): self.alertForm.loadList() self.alertForm.exec_() - def onAlertsEdit(self): - self.alertEditForm.loadList() - self.alertEditForm.exec_() - def about(self): about_text = self.trUtf8('Alerts Plugin
This plugin ' 'controls the displaying of alerts on the presentations screen') diff --git a/openlp/plugins/alerts/forms/alertstab.py b/openlp/plugins/alerts/forms/alertstab.py index c842c2e20..4651b14c5 100644 --- a/openlp/plugins/alerts/forms/alertstab.py +++ b/openlp/plugins/alerts/forms/alertstab.py @@ -26,6 +26,7 @@ from PyQt4 import QtCore, QtGui from openlp.core.lib import SettingsTab, str_to_bool +from openlp.plugins.alerts.lib.models import AlertItem class AlertsTab(SettingsTab): """ @@ -33,6 +34,7 @@ class AlertsTab(SettingsTab): """ def __init__(self, parent, section=None): self.parent = parent + self.manager = parent.manager SettingsTab.__init__(self, parent.name, section) def setupUi(self): @@ -149,22 +151,6 @@ class AlertsTab(SettingsTab): QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Minimum) self.HistoryLayout.addItem(self.HistorySpacer) self.FontLayout.addWidget(self.HistoryWidget) - self.HistoryEditWidget = QtGui.QWidget(self.FontGroupBox) - self.HistoryEditWidget.setObjectName(u'HistoryEditWidget') - self.HistoryEditLayout = QtGui.QHBoxLayout(self.HistoryEditWidget) - self.HistoryEditLayout.setSpacing(8) - self.HistoryEditLayout.setMargin(0) - self.HistoryEditLayout.setObjectName(u'HistoryEditLayout') - self.HistoryEditLabel = QtGui.QLabel(self.HistoryEditWidget) - self.HistoryEditLabel.setObjectName(u'HistoryEditLabel') - self.HistoryEditLayout.addWidget(self.HistoryEditLabel) - self.HistoryEditPushButton = QtGui.QPushButton(self.HistoryEditWidget) - self.HistoryEditPushButton.setObjectName(u'HistoryEditPushButton') - self.HistoryEditLayout.addWidget(self.HistoryEditPushButton) - self.HistoryEditSpacer = QtGui.QSpacerItem(147, 20, - QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Minimum) - self.HistoryEditLayout.addItem(self.HistoryEditSpacer) - self.FontLayout.addWidget(self.HistoryEditWidget) self.SlideLeftLayout.addWidget(self.FontGroupBox) self.SlideLeftSpacer = QtGui.QSpacerItem(20, 94, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding) @@ -201,6 +187,43 @@ class AlertsTab(SettingsTab): self.SlideRightSpacer = QtGui.QSpacerItem(20, 40, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding) self.SlideRightLayout.addItem(self.SlideRightSpacer) + self.layoutWidget = QtGui.QWidget(self) + self.layoutWidget.setGeometry(QtCore.QRect(20, 10, 361, 251)) + self.layoutWidget.setObjectName(u'layoutWidget') + self.verticalLayout_2 = QtGui.QVBoxLayout(self.layoutWidget) + self.verticalLayout_2.setObjectName(u'verticalLayout_2') + self.horizontalLayout_2 = QtGui.QHBoxLayout() + self.horizontalLayout_2.setObjectName(u'horizontalLayout_2') + self.AlertLineEdit = QtGui.QLineEdit(self.layoutWidget) + self.AlertLineEdit.setObjectName(u'AlertLineEdit') + self.horizontalLayout_2.addWidget(self.AlertLineEdit) + self.verticalLayout_2.addLayout(self.horizontalLayout_2) + self.horizontalLayout = QtGui.QHBoxLayout() + self.horizontalLayout.setObjectName(u'horizontalLayout') + self.AlertListWidget = QtGui.QListWidget(self.layoutWidget) + self.AlertListWidget.setAlternatingRowColors(True) + self.AlertListWidget.setObjectName(u'AlertListWidget') + self.horizontalLayout.addWidget(self.AlertListWidget) + self.verticalLayout = QtGui.QVBoxLayout() + self.verticalLayout.setObjectName(u'verticalLayout') + self.SaveButton = QtGui.QPushButton(self.layoutWidget) + self.SaveButton.setObjectName(u'SaveButton') + self.verticalLayout.addWidget(self.SaveButton) + self.ClearButton = QtGui.QPushButton(self.layoutWidget) + self.ClearButton.setObjectName(u'ClearButton') + self.verticalLayout.addWidget(self.ClearButton) + self.AddButton = QtGui.QPushButton(self.layoutWidget) + self.AddButton.setObjectName(u'AddButton') + self.verticalLayout.addWidget(self.AddButton) + self.EditButton = QtGui.QPushButton(self.layoutWidget) + self.EditButton.setObjectName(u'EditButton') + self.verticalLayout.addWidget(self.EditButton) + self.DeleteButton = QtGui.QPushButton(self.layoutWidget) + self.DeleteButton.setObjectName(u'DeleteButton') + self.verticalLayout.addWidget(self.DeleteButton) + self.horizontalLayout.addLayout(self.verticalLayout) + self.verticalLayout_2.addLayout(self.horizontalLayout) + self.SlideRightLayout.addWidget(self.layoutWidget) self.AlertsLayout.addWidget(self.AlertRightColumn) # Signals and slots QtCore.QObject.connect(self.HistoryCheckBox, @@ -210,8 +233,6 @@ class AlertsTab(SettingsTab): QtCore.SIGNAL(u'pressed()'), self.onBackgroundColorButtonClicked) QtCore.QObject.connect(self.FontColorButton, QtCore.SIGNAL(u'pressed()'), self.onFontColorButtonClicked) - QtCore.QObject.connect(self.HistoryEditPushButton, - QtCore.SIGNAL(u'pressed()'), self.onHistoryEditButtonClicked) QtCore.QObject.connect(self.FontComboBox, QtCore.SIGNAL(u'activated(int)'), self.onFontComboBoxClicked) QtCore.QObject.connect(self.LocationComboBox, @@ -220,6 +241,27 @@ class AlertsTab(SettingsTab): QtCore.SIGNAL(u'valueChanged(int)'), self.onTimeoutSpinBoxChanged) QtCore.QObject.connect(self.FontSizeSpinBox, QtCore.SIGNAL(u'valueChanged(int)'), self.onFontSizeSpinBoxChanged) + QtCore.QObject.connect(self.DeleteButton, + QtCore.SIGNAL(u'clicked()'), + self.onDeleteClick) + QtCore.QObject.connect(self.ClearButton, + QtCore.SIGNAL(u'clicked()'), + self.onClearClick) + QtCore.QObject.connect(self.EditButton, + QtCore.SIGNAL(u'clicked()'), + self.onEditClick) + QtCore.QObject.connect(self.AddButton, + QtCore.SIGNAL(u'clicked()'), + self.onAddClick) + QtCore.QObject.connect(self.SaveButton, + QtCore.SIGNAL(u'clicked()'), + self.onSaveClick) + QtCore.QObject.connect(self.AlertListWidget, + QtCore.SIGNAL(u'doubleClicked(QModelIndex)'), + self.onItemSelected) + QtCore.QObject.connect(self.AlertListWidget, + QtCore.SIGNAL(u'clicked(QModelIndex)'), + self.onItemSelected) def retranslateUi(self): self.FontGroupBox.setTitle(self.trUtf8('Font')) @@ -232,11 +274,15 @@ class AlertsTab(SettingsTab): self.TimeoutSpinBox.setSuffix(self.trUtf8('s')) self.LocationLabel.setText(self.trUtf8('Location:')) self.HistoryLabel.setText(self.trUtf8('Keep History:')) - self.HistoryEditLabel.setText(self.trUtf8('Edit History:')) self.PreviewGroupBox.setTitle(self.trUtf8('Preview')) self.FontPreview.setText(self.trUtf8('openlp.org')) self.LocationComboBox.setItemText(0, self.trUtf8('Top')) self.LocationComboBox.setItemText(1, self.trUtf8('Bottom')) + self.SaveButton.setText(self.trUtf8('Save')) + self.ClearButton.setText(self.trUtf8('Clear')) + self.AddButton.setText(self.trUtf8('Add')) + self.EditButton.setText(self.trUtf8('Edit')) + self.DeleteButton.setText(self.trUtf8('Delete')) def onBackgroundColorButtonClicked(self): self.bg_color = QtGui.QColorDialog.getColor( @@ -271,9 +317,6 @@ class AlertsTab(SettingsTab): self.font_size = self.FontSizeSpinBox.value() self.updateDisplay() - def onHistoryEditButtonClicked(self): - self.parent.onAlertsEdit() - def load(self): self.timeout = int(self.config.get_config(u'timeout', 5)) self.font_color = unicode( @@ -298,6 +341,75 @@ class AlertsTab(SettingsTab): font.setFamily(self.font_face) self.FontComboBox.setCurrentFont(font) self.updateDisplay() + self.loadList() + + def loadList(self): + self.AlertListWidget.clear() + alerts = self.manager.get_all_alerts() + for alert in alerts: + item_name = QtGui.QListWidgetItem(alert.text) + item_name.setData( + QtCore.Qt.UserRole, QtCore.QVariant(alert.id)) + self.AlertListWidget.addItem(item_name) + self.AddButton.setEnabled(True) + self.ClearButton.setEnabled(False) + self.SaveButton.setEnabled(False) + self.EditButton.setEnabled(False) + self.DeleteButton.setEnabled(False) + + def onItemSelected(self): + self.EditButton.setEnabled(True) + self.DeleteButton.setEnabled(True) + + def onDeleteClick(self): + item = self.AlertListWidget.currentItem() + if item: + item_id = (item.data(QtCore.Qt.UserRole)).toInt()[0] + self.parent.manager.delete_alert(item_id) + row = self.AlertListWidget.row(item) + self.AlertListWidget.takeItem(row) + self.AddButton.setEnabled(True) + self.SaveButton.setEnabled(False) + self.DeleteButton.setEnabled(False) + self.EditButton.setEnabled(False) + + def onEditClick(self): + item = self.AlertListWidget.currentItem() + if item: + self.item_id = (item.data(QtCore.Qt.UserRole)).toInt()[0] + self.AlertLineEdit.setText(unicode(item.text())) + self.AddButton.setEnabled(True) + self.ClearButton.setEnabled(True) + self.SaveButton.setEnabled(True) + self.DeleteButton.setEnabled(True) + self.EditButton.setEnabled(False) + + def onClearClick(self): + self.AlertLineEdit.setText(u'') + self.AddButton.setEnabled(False) + self.ClearButton.setEnabled(True) + self.SaveButton.setEnabled(False) + self.DeleteButton.setEnabled(False) + self.EditButton.setEnabled(False) + + def onAddClick(self): + if len(self.AlertLineEdit.text()) == 0: + QtGui.QMessageBox.information(self, + self.trUtf8('Item selected to Add'), + self.trUtf8('Missing data')) + else: + alert = AlertItem() + alert.text = unicode(self.AlertLineEdit.text()) + self.manager.save_alert(alert) + self.onClearClick() + self.loadList() + + def onSaveClick(self): + alert = self.manager.get_alert(self.item_id) + alert.text = unicode(self.AlertLineEdit.text()) + self.manager.save_alert(alert) + self.onClearClick() + self.loadList() def save(self): self.font_face = self.FontComboBox.currentFont().family() From a71505a10c4fbde35c7c5c5fa13a0d785df2dc4f Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Wed, 17 Mar 2010 19:09:09 +0000 Subject: [PATCH 05/30] Bible can add verses to service item --- openlp/plugins/bibles/lib/mediaitem.py | 1 + 1 file changed, 1 insertion(+) diff --git a/openlp/plugins/bibles/lib/mediaitem.py b/openlp/plugins/bibles/lib/mediaitem.py index 30403e69d..861289682 100644 --- a/openlp/plugins/bibles/lib/mediaitem.py +++ b/openlp/plugins/bibles/lib/mediaitem.py @@ -58,6 +58,7 @@ class BibleMediaItem(MediaManagerItem): self.ListViewWithDnD_class = BibleListView self.servicePath = None self.lastReference = [] + self.addToServiceItem = True MediaManagerItem.__init__(self, parent, icon, title) # place to store the search results self.search_results = {} From 72d2d8f83d05c41b95e06df82a40510ef9609c66 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Wed, 17 Mar 2010 21:08:18 +0000 Subject: [PATCH 06/30] Clean up service item form names --- openlp/core/ui/__init__.py | 3 +- openlp/core/ui/serviceitemeditdialog.py | 53 +++++++++++++ openlp/core/ui/serviceitemeditform.py | 44 +++++++++++ openlp/core/ui/servicemanager.py | 10 +-- ...viceitemdialog.py => servicenotedialog.py} | 0 ...{serviceitemform.py => servicenoteform.py} | 2 +- resources/forms/serviceitemeditdialog.ui | 74 +++++++++++++++++++ ...viceitemdialog.ui => servicenotedialog.ui} | 0 8 files changed, 179 insertions(+), 7 deletions(-) create mode 100644 openlp/core/ui/serviceitemeditdialog.py create mode 100644 openlp/core/ui/serviceitemeditform.py rename openlp/core/ui/{serviceitemdialog.py => servicenotedialog.py} (100%) rename openlp/core/ui/{serviceitemform.py => servicenoteform.py} (97%) create mode 100644 resources/forms/serviceitemeditdialog.ui rename resources/forms/{serviceitemdialog.ui => servicenotedialog.ui} (100%) diff --git a/openlp/core/ui/__init__.py b/openlp/core/ui/__init__.py index c2f571c3b..98d85089d 100644 --- a/openlp/core/ui/__init__.py +++ b/openlp/core/ui/__init__.py @@ -23,7 +23,8 @@ # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### -from serviceitemform import ServiceItemNoteForm +from servicenoteform import ServiceNoteForm +from serviceitemeditform import ServiceItemEditForm from screen import ScreenList from maindisplay import MainDisplay from amendthemeform import AmendThemeForm diff --git a/openlp/core/ui/serviceitemeditdialog.py b/openlp/core/ui/serviceitemeditdialog.py new file mode 100644 index 000000000..f8d643a94 --- /dev/null +++ b/openlp/core/ui/serviceitemeditdialog.py @@ -0,0 +1,53 @@ +# -*- coding: utf-8 -*- + +# Form implementation generated from reading ui file 'serviceitemeditdialog.ui' +# +# Created: Wed Mar 17 20:55:46 2010 +# by: PyQt4 UI code generator 4.7 +# +# WARNING! All changes made in this file will be lost! + +from PyQt4 import QtCore, QtGui + +class Ui_ServiceItemEditDialog(object): + def setupUi(self, ServiceItemEditDialog): + ServiceItemEditDialog.setObjectName("ServiceItemEditDialog") + ServiceItemEditDialog.resize(400, 287) + self.widget = QtGui.QWidget(ServiceItemEditDialog) + self.widget.setGeometry(QtCore.QRect(20, 20, 351, 241)) + self.widget.setObjectName("widget") + self.verticalLayout_2 = QtGui.QVBoxLayout(self.widget) + self.verticalLayout_2.setObjectName("verticalLayout_2") + self.horizontalLayout = QtGui.QHBoxLayout() + self.horizontalLayout.setObjectName("horizontalLayout") + self.listWidget = QtGui.QListWidget(self.widget) + self.listWidget.setAlternatingRowColors(True) + self.listWidget.setObjectName("listWidget") + self.horizontalLayout.addWidget(self.listWidget) + self.verticalLayout = QtGui.QVBoxLayout() + self.verticalLayout.setObjectName("verticalLayout") + self.upButton = QtGui.QPushButton(self.widget) + self.upButton.setObjectName("upButton") + self.verticalLayout.addWidget(self.upButton) + self.downButton = QtGui.QPushButton(self.widget) + self.downButton.setObjectName("downButton") + self.verticalLayout.addWidget(self.downButton) + self.deleteButton = QtGui.QPushButton(self.widget) + self.deleteButton.setObjectName("deleteButton") + self.verticalLayout.addWidget(self.deleteButton) + self.horizontalLayout.addLayout(self.verticalLayout) + self.verticalLayout_2.addLayout(self.horizontalLayout) + self.buttonBox = QtGui.QDialogButtonBox(self.widget) + self.buttonBox.setStandardButtons(QtGui.QDialogButtonBox.Cancel|QtGui.QDialogButtonBox.Save) + self.buttonBox.setObjectName("buttonBox") + self.verticalLayout_2.addWidget(self.buttonBox) + + self.retranslateUi(ServiceItemEditDialog) + QtCore.QMetaObject.connectSlotsByName(ServiceItemEditDialog) + + def retranslateUi(self, ServiceItemEditDialog): + ServiceItemEditDialog.setWindowTitle(QtGui.QApplication.translate("ServiceItemEditDialog", "Service Item Maintenance", None, QtGui.QApplication.UnicodeUTF8)) + self.upButton.setText(QtGui.QApplication.translate("ServiceItemEditDialog", "Up", None, QtGui.QApplication.UnicodeUTF8)) + self.downButton.setText(QtGui.QApplication.translate("ServiceItemEditDialog", "Down", None, QtGui.QApplication.UnicodeUTF8)) + self.deleteButton.setText(QtGui.QApplication.translate("ServiceItemEditDialog", "Delete", None, QtGui.QApplication.UnicodeUTF8)) + diff --git a/openlp/core/ui/serviceitemeditform.py b/openlp/core/ui/serviceitemeditform.py new file mode 100644 index 000000000..f251140a5 --- /dev/null +++ b/openlp/core/ui/serviceitemeditform.py @@ -0,0 +1,44 @@ +# -*- coding: utf-8 -*- +# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4 + +############################################################################### +# OpenLP - Open Source Lyrics Projection # +# --------------------------------------------------------------------------- # +# Copyright (c) 2008-2010 Raoul Snyman # +# Portions copyright (c) 2008-2010 Tim Bentley, Jonathan Corwin, Michael # +# Gorven, Scott Guerrieri, Maikel Stuivenberg, Martin Thompson, Jon Tibble, # +# Carsten Tinggaard # +# --------------------------------------------------------------------------- # +# 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 PyQt4 import QtCore, QtGui +from serviceitemeditdialog import Ui_ServiceItemEditDialog + +class ServiceItemEditForm(QtGui.QDialog, Ui_ServiceItemEditDialog): + """ + This is the form that is used to edit the verses of the song. + """ + def __init__(self, parent=None): + """ + Constructor + """ + QtGui.QDialog.__init__(self, parent) + self.setupUi(self) + QtCore.QObject.connect(self.buttonBox, + QtCore.SIGNAL(u'accepted()'), + self.accept) + QtCore.QObject.connect(self.buttonBox, + QtCore.SIGNAL(u'rejected()'), + self.reject) diff --git a/openlp/core/ui/servicemanager.py b/openlp/core/ui/servicemanager.py index fff903648..9c429e88c 100644 --- a/openlp/core/ui/servicemanager.py +++ b/openlp/core/ui/servicemanager.py @@ -34,7 +34,7 @@ from PyQt4 import QtCore, QtGui from openlp.core.lib import PluginConfig, OpenLPToolbar, ServiceItem, \ contextMenuAction, Receiver, str_to_bool, build_icon -from openlp.core.ui import ServiceItemNoteForm +from openlp.core.ui import ServiceNoteForm, ServiceItemEditForm class ServiceManagerList(QtGui.QTreeWidget): @@ -106,7 +106,7 @@ class ServiceManager(QtGui.QWidget): #Indicates if remoteTriggering is active. If it is the next addServiceItem call #will replace the currently selected one. self.remoteEditTriggered = False - self.serviceItemNoteForm = ServiceItemNoteForm() + self.serviceNoteForm = ServiceNoteForm() #start with the layout self.Layout = QtGui.QVBoxLayout(self) self.Layout.setSpacing(0) @@ -257,11 +257,11 @@ class ServiceManager(QtGui.QWidget): def onServiceItemNoteForm(self): item, count = self.findServiceItem() - self.serviceItemNoteForm.textEdit.setPlainText( + self.serviceNoteForm.textEdit.setPlainText( self.serviceItems[item][u'service_item'].notes) - if self.serviceItemNoteForm.exec_(): + if self.serviceNoteForm.exec_(): self.serviceItems[item][u'service_item'].notes = \ - self.serviceItemNoteForm.textEdit.toPlainText() + self.serviceNoteForm.textEdit.toPlainText() self.repaintServiceList(item, 0) def nextItem(self): diff --git a/openlp/core/ui/serviceitemdialog.py b/openlp/core/ui/servicenotedialog.py similarity index 100% rename from openlp/core/ui/serviceitemdialog.py rename to openlp/core/ui/servicenotedialog.py diff --git a/openlp/core/ui/serviceitemform.py b/openlp/core/ui/servicenoteform.py similarity index 97% rename from openlp/core/ui/serviceitemform.py rename to openlp/core/ui/servicenoteform.py index 43011ead8..9ec4c9696 100644 --- a/openlp/core/ui/serviceitemform.py +++ b/openlp/core/ui/servicenoteform.py @@ -26,7 +26,7 @@ from PyQt4 import QtCore, QtGui from serviceitemdialog import Ui_ServiceNoteEdit -class ServiceItemNoteForm(QtGui.QDialog, Ui_ServiceNoteEdit): +class ServiceNoteForm(QtGui.QDialog, Ui_ServiceNoteEdit): """ This is the form that is used to edit the verses of the song. """ diff --git a/resources/forms/serviceitemeditdialog.ui b/resources/forms/serviceitemeditdialog.ui new file mode 100644 index 000000000..7e2be8087 --- /dev/null +++ b/resources/forms/serviceitemeditdialog.ui @@ -0,0 +1,74 @@ + + + ServiceItemEditDialog + + + + 0 + 0 + 400 + 287 + + + + Service Item Maintenance + + + + + 20 + 20 + 351 + 241 + + + + + + + + + true + + + + + + + + + Up + + + + + + + Down + + + + + + + Delete + + + + + + + + + + + QDialogButtonBox::Cancel|QDialogButtonBox::Save + + + + + + + + + diff --git a/resources/forms/serviceitemdialog.ui b/resources/forms/servicenotedialog.ui similarity index 100% rename from resources/forms/serviceitemdialog.ui rename to resources/forms/servicenotedialog.ui From ff8145cef120ea922cce01d9aa57547c69d88f06 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Wed, 17 Mar 2010 21:25:35 +0000 Subject: [PATCH 07/30] Add in maintenance page to service manager --- openlp/core/ui/servicemanager.py | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/openlp/core/ui/servicemanager.py b/openlp/core/ui/servicemanager.py index 9c429e88c..386d7af8d 100644 --- a/openlp/core/ui/servicemanager.py +++ b/openlp/core/ui/servicemanager.py @@ -107,6 +107,7 @@ class ServiceManager(QtGui.QWidget): #will replace the currently selected one. self.remoteEditTriggered = False self.serviceNoteForm = ServiceNoteForm() + self.serviceItemEditForm = ServiceItemEditForm() #start with the layout self.Layout = QtGui.QVBoxLayout(self) self.Layout.setSpacing(0) @@ -243,6 +244,8 @@ class ServiceManager(QtGui.QWidget): action = self.menu.exec_(self.ServiceManagerList.mapToGlobal(point)) if action == self.editAction: self.remoteEdit() + if action == self.maintainAction: + self.onServiceItemEditForm() if action == self.deleteAction: self.onDeleteFromService() if action == self.notesAction: @@ -264,6 +267,12 @@ class ServiceManager(QtGui.QWidget): self.serviceNoteForm.textEdit.toPlainText() self.repaintServiceList(item, 0) + def onServiceItemEditForm(self): + item, count = self.findServiceItem() + if self.serviceItemEditForm.exec_(): + pass + + def nextItem(self): """ Called by the SlideController to select the From 44224b0c73adeed6eab6eb07c4e790720ceb0792 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Thu, 18 Mar 2010 21:50:20 +0000 Subject: [PATCH 08/30] Fix up maintenance dialog --- openlp/core/lib/serviceitem.py | 13 +++-- openlp/core/ui/serviceitemeditdialog.py | 28 +++++++-- openlp/core/ui/serviceitemeditform.py | 76 +++++++++++++++++++++++++ openlp/core/ui/servicemanager.py | 11 ++-- openlp/plugins/bibles/lib/mediaitem.py | 5 +- 5 files changed, 116 insertions(+), 17 deletions(-) diff --git a/openlp/core/lib/serviceitem.py b/openlp/core/lib/serviceitem.py index 9164f3235..09c5ac8b9 100644 --- a/openlp/core/lib/serviceitem.py +++ b/openlp/core/lib/serviceitem.py @@ -66,7 +66,6 @@ class ServiceItem(object): self.iconic_representation = None self.raw_footer = None self.theme = None - self.service_item_path = None self.service_item_type = None self.edit_enabled = False self.maintain_allowed = False @@ -157,9 +156,8 @@ class ServiceItem(object): The actual image file name. """ self.service_item_type = ServiceItemType.Image - self.service_item_path = path self._raw_frames.append( - {u'title': title, u'image': image}) + {u'title': title, u'image': image, u'path': path}) def add_from_text(self, title, raw_slide, verseTag=None): """ @@ -190,9 +188,8 @@ class ServiceItem(object): The command of/for the slide. """ self.service_item_type = ServiceItemType.Command - self.service_item_path = path self._raw_frames.append( - {u'title': file_name, u'image': image}) + {u'title': file_name, u'image': image, u'path': path}) def get_service_repr(self): """ @@ -209,7 +206,9 @@ class ServiceItem(object): u'type':self.service_item_type, u'audit':self.audit, u'notes':self.notes, - u'preview':self.autoPreviewAllowed + u'preview':self.autoPreviewAllowed, + u'edit':self.edit_enabled, + u'maintain':self.maintain_allowed } service_data = [] if self.service_item_type == ServiceItemType.Text: @@ -245,6 +244,8 @@ class ServiceItem(object): self.audit = header[u'audit'] self.autoPreviewAllowed = header[u'preview'] self.notes = header[u'notes'] + self.edit_enabled = header[u'edit'] + self.maintain_allowed = header[u'maintain'] if self.service_item_type == ServiceItemType.Text: for slide in serviceitem[u'serviceitem'][u'data']: self._raw_frames.append(slide) diff --git a/openlp/core/ui/serviceitemeditdialog.py b/openlp/core/ui/serviceitemeditdialog.py index f8d643a94..b0ca3bf30 100644 --- a/openlp/core/ui/serviceitemeditdialog.py +++ b/openlp/core/ui/serviceitemeditdialog.py @@ -1,11 +1,27 @@ # -*- coding: utf-8 -*- +# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4 -# Form implementation generated from reading ui file 'serviceitemeditdialog.ui' -# -# Created: Wed Mar 17 20:55:46 2010 -# by: PyQt4 UI code generator 4.7 -# -# WARNING! All changes made in this file will be lost! +############################################################################### +# OpenLP - Open Source Lyrics Projection # +# --------------------------------------------------------------------------- # +# Copyright (c) 2008-2010 Raoul Snyman # +# Portions copyright (c) 2008-2010 Tim Bentley, Jonathan Corwin, Michael # +# Gorven, Scott Guerrieri, Maikel Stuivenberg, Martin Thompson, Jon Tibble, # +# Carsten Tinggaard # +# --------------------------------------------------------------------------- # +# 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 PyQt4 import QtCore, QtGui diff --git a/openlp/core/ui/serviceitemeditform.py b/openlp/core/ui/serviceitemeditform.py index f251140a5..cbe530d80 100644 --- a/openlp/core/ui/serviceitemeditform.py +++ b/openlp/core/ui/serviceitemeditform.py @@ -36,9 +36,85 @@ class ServiceItemEditForm(QtGui.QDialog, Ui_ServiceItemEditDialog): """ QtGui.QDialog.__init__(self, parent) self.setupUi(self) + self.itemList = [] + # enable drop + QtCore.QObject.connect(self.upButton, + QtCore.SIGNAL(u'clicked()'), + self.onItemUp) + QtCore.QObject.connect(self.downButton, + QtCore.SIGNAL(u'clicked()'), + self.onItemDown) + QtCore.QObject.connect(self.deleteButton, + QtCore.SIGNAL(u'clicked()'), + self.onItemDelete) QtCore.QObject.connect(self.buttonBox, QtCore.SIGNAL(u'accepted()'), self.accept) QtCore.QObject.connect(self.buttonBox, QtCore.SIGNAL(u'rejected()'), self.reject) + + def setServiceItem(self, item): + self.item = item + self.itemList = [] + if self.item.is_image(): + self.data = True + for frame in self.item._raw_frames: + self.itemList.append(frame) + self.loadData() + + def getServiceItem(self): + if self.data: + self.item._raw_frames = [] + if self.item.is_image(): + for item in self.itemList: + self.item.add_from_image(item[u'path'], + item[u'title'], item[u'image']) + self.item.render() + return self.item + + def loadData(self): + self.listWidget.clear() + for frame in self.itemList: + item_name = QtGui.QListWidgetItem(frame[u'title']) + self.listWidget.addItem(item_name) + + def onItemDelete(self): + """ + Move the current ServiceItem up in the list + Note move up means move to top of area ie 0. + """ + items = self.listWidget.selectedItems() + for item in items: + row = self.listWidget.row(item) + if row > 0: + self.itemList.remove(self.itemList[row]) + self.loadData() + + def onItemUp(self): + """ + Move the current ServiceItem up in the list + Note move up means move to top of area ie 0. + """ + items = self.listWidget.selectedItems() + for item in items: + row = self.listWidget.row(item) + if row > 0: + temp = self.itemList[row] + self.itemList.remove(self.itemList[row]) + self.itemList.insert(row - 1, temp) + self.loadData() + + def onItemDown(self): + """ + Move the current ServiceItem down in the list + Note move down means move to bottom of area i.e len(). + """ + items = self.listWidget.selectedItems() + for item in items: + row = self.listWidget.row(item) + if row < len(self.itemList) and row is not -1: + temp = self.itemList[row] + self.itemList.remove(self.itemList[row]) + self.itemList.insert(row + 1, temp) + self.loadData() diff --git a/openlp/core/ui/servicemanager.py b/openlp/core/ui/servicemanager.py index 386d7af8d..3225d9237 100644 --- a/openlp/core/ui/servicemanager.py +++ b/openlp/core/ui/servicemanager.py @@ -269,9 +269,12 @@ class ServiceManager(QtGui.QWidget): def onServiceItemEditForm(self): item, count = self.findServiceItem() + self.serviceItemEditForm.setServiceItem( + self.serviceItems[item][u'service_item']) if self.serviceItemEditForm.exec_(): - pass - + self.serviceItems[item][u'service_item'] = \ + self.serviceItemEditForm.getServiceItem() + self.repaintServiceList(item, 0) def nextItem(self): """ @@ -367,7 +370,7 @@ class ServiceManager(QtGui.QWidget): def onServiceUp(self): """ Move the current ServiceItem up in the list - Note move up means move to top of area ie 0. + Note move up means move to top of area ie 0. """ item, count = self.findServiceItem() if item > 0: @@ -513,7 +516,7 @@ class ServiceManager(QtGui.QWidget): if item[u'service_item'].uses_file(): for frame in item[u'service_item'].get_frames(): path_from = unicode(os.path.join( - item[u'service_item'].service_item_path, + frame[u'path'], frame[u'title'])) zip.write(path_from) file = open(servicefile, u'wb') diff --git a/openlp/plugins/bibles/lib/mediaitem.py b/openlp/plugins/bibles/lib/mediaitem.py index 861289682..c2aaf0d64 100644 --- a/openlp/plugins/bibles/lib/mediaitem.py +++ b/openlp/plugins/bibles/lib/mediaitem.py @@ -492,7 +492,10 @@ class BibleMediaItem(MediaManagerItem): if self.parent.settings_tab.layout_style == 0: raw_slides.append(bible_text) bible_text = u'' - service_item.title = u'%s %s' % (book, verse_text) + if not service_item.title: + service_item.title = u'%s %s' % (book, verse_text) + elif service_item.title.find(self.trUtf8(u'etc')) == -1: + service_item.title = u'%s, %s' % (service_item.title, self.trUtf8(u'etc')) if len(self.parent.settings_tab.bible_theme) == 0: service_item.theme = None else: From 66b23f6a6fc7f1a29a9c2759a2678e2f19404b2a Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Thu, 18 Mar 2010 22:06:51 +0000 Subject: [PATCH 09/30] Fix dialog --- openlp/core/ui/serviceitemeditdialog.py | 78 ++++++++++-------------- resources/forms/serviceitemeditdialog.ui | 33 +++++++--- 2 files changed, 55 insertions(+), 56 deletions(-) diff --git a/openlp/core/ui/serviceitemeditdialog.py b/openlp/core/ui/serviceitemeditdialog.py index b0ca3bf30..bb1666418 100644 --- a/openlp/core/ui/serviceitemeditdialog.py +++ b/openlp/core/ui/serviceitemeditdialog.py @@ -1,62 +1,48 @@ # -*- coding: utf-8 -*- -# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4 -############################################################################### -# OpenLP - Open Source Lyrics Projection # -# --------------------------------------------------------------------------- # -# Copyright (c) 2008-2010 Raoul Snyman # -# Portions copyright (c) 2008-2010 Tim Bentley, Jonathan Corwin, Michael # -# Gorven, Scott Guerrieri, Maikel Stuivenberg, Martin Thompson, Jon Tibble, # -# Carsten Tinggaard # -# --------------------------------------------------------------------------- # -# 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 # -############################################################################### +# Form implementation generated from reading ui file 'serviceitemeditdialog.ui' +# +# Created: Thu Mar 18 22:05:22 2010 +# by: PyQt4 UI code generator 4.7 +# +# WARNING! All changes made in this file will be lost! from PyQt4 import QtCore, QtGui class Ui_ServiceItemEditDialog(object): def setupUi(self, ServiceItemEditDialog): ServiceItemEditDialog.setObjectName("ServiceItemEditDialog") - ServiceItemEditDialog.resize(400, 287) - self.widget = QtGui.QWidget(ServiceItemEditDialog) - self.widget.setGeometry(QtCore.QRect(20, 20, 351, 241)) - self.widget.setObjectName("widget") - self.verticalLayout_2 = QtGui.QVBoxLayout(self.widget) - self.verticalLayout_2.setObjectName("verticalLayout_2") - self.horizontalLayout = QtGui.QHBoxLayout() - self.horizontalLayout.setObjectName("horizontalLayout") - self.listWidget = QtGui.QListWidget(self.widget) + ServiceItemEditDialog.resize(386, 272) + self.layoutWidget = QtGui.QWidget(ServiceItemEditDialog) + self.layoutWidget.setGeometry(QtCore.QRect(20, 20, 351, 241)) + self.layoutWidget.setObjectName("layoutWidget") + self.outerLayout = QtGui.QVBoxLayout(self.layoutWidget) + self.outerLayout.setObjectName("outerLayout") + self.topLayout = QtGui.QHBoxLayout() + self.topLayout.setObjectName("topLayout") + self.listWidget = QtGui.QListWidget(self.layoutWidget) self.listWidget.setAlternatingRowColors(True) self.listWidget.setObjectName("listWidget") - self.horizontalLayout.addWidget(self.listWidget) - self.verticalLayout = QtGui.QVBoxLayout() - self.verticalLayout.setObjectName("verticalLayout") - self.upButton = QtGui.QPushButton(self.widget) + self.topLayout.addWidget(self.listWidget) + self.buttonLayout = QtGui.QVBoxLayout() + self.buttonLayout.setObjectName("buttonLayout") + self.upButton = QtGui.QPushButton(self.layoutWidget) self.upButton.setObjectName("upButton") - self.verticalLayout.addWidget(self.upButton) - self.downButton = QtGui.QPushButton(self.widget) - self.downButton.setObjectName("downButton") - self.verticalLayout.addWidget(self.downButton) - self.deleteButton = QtGui.QPushButton(self.widget) + self.buttonLayout.addWidget(self.upButton) + spacerItem = QtGui.QSpacerItem(20, 40, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding) + self.buttonLayout.addItem(spacerItem) + self.deleteButton = QtGui.QPushButton(self.layoutWidget) self.deleteButton.setObjectName("deleteButton") - self.verticalLayout.addWidget(self.deleteButton) - self.horizontalLayout.addLayout(self.verticalLayout) - self.verticalLayout_2.addLayout(self.horizontalLayout) - self.buttonBox = QtGui.QDialogButtonBox(self.widget) + self.buttonLayout.addWidget(self.deleteButton) + self.downButton = QtGui.QPushButton(self.layoutWidget) + self.downButton.setObjectName("downButton") + self.buttonLayout.addWidget(self.downButton) + self.topLayout.addLayout(self.buttonLayout) + self.outerLayout.addLayout(self.topLayout) + self.buttonBox = QtGui.QDialogButtonBox(self.layoutWidget) self.buttonBox.setStandardButtons(QtGui.QDialogButtonBox.Cancel|QtGui.QDialogButtonBox.Save) self.buttonBox.setObjectName("buttonBox") - self.verticalLayout_2.addWidget(self.buttonBox) + self.outerLayout.addWidget(self.buttonBox) self.retranslateUi(ServiceItemEditDialog) QtCore.QMetaObject.connectSlotsByName(ServiceItemEditDialog) @@ -64,6 +50,6 @@ class Ui_ServiceItemEditDialog(object): def retranslateUi(self, ServiceItemEditDialog): ServiceItemEditDialog.setWindowTitle(QtGui.QApplication.translate("ServiceItemEditDialog", "Service Item Maintenance", None, QtGui.QApplication.UnicodeUTF8)) self.upButton.setText(QtGui.QApplication.translate("ServiceItemEditDialog", "Up", None, QtGui.QApplication.UnicodeUTF8)) - self.downButton.setText(QtGui.QApplication.translate("ServiceItemEditDialog", "Down", None, QtGui.QApplication.UnicodeUTF8)) self.deleteButton.setText(QtGui.QApplication.translate("ServiceItemEditDialog", "Delete", None, QtGui.QApplication.UnicodeUTF8)) + self.downButton.setText(QtGui.QApplication.translate("ServiceItemEditDialog", "Down", None, QtGui.QApplication.UnicodeUTF8)) diff --git a/resources/forms/serviceitemeditdialog.ui b/resources/forms/serviceitemeditdialog.ui index 7e2be8087..24c86b966 100644 --- a/resources/forms/serviceitemeditdialog.ui +++ b/resources/forms/serviceitemeditdialog.ui @@ -6,14 +6,14 @@ 0 0 - 400 - 287 + 386 + 272 Service Item Maintenance - + 20 @@ -22,9 +22,9 @@ 241 - + - + @@ -33,7 +33,7 @@ - + @@ -42,11 +42,17 @@ - - - Down + + + Qt::Vertical - + + + 20 + 40 + + + @@ -55,6 +61,13 @@ + + + + Down + + + From 09f18fd96d4f2ebea394b97e2a43294126ceb736 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Fri, 19 Mar 2010 07:23:48 +0000 Subject: [PATCH 10/30] Clean up maintenance - Complete --- openlp/core/ui/serviceitemeditdialog.py | 62 ++++++++++++++++--------- openlp/core/ui/serviceitemeditform.py | 14 ++---- 2 files changed, 45 insertions(+), 31 deletions(-) diff --git a/openlp/core/ui/serviceitemeditdialog.py b/openlp/core/ui/serviceitemeditdialog.py index bb1666418..b388fb98c 100644 --- a/openlp/core/ui/serviceitemeditdialog.py +++ b/openlp/core/ui/serviceitemeditdialog.py @@ -1,55 +1,73 @@ # -*- coding: utf-8 -*- +# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4 -# Form implementation generated from reading ui file 'serviceitemeditdialog.ui' -# -# Created: Thu Mar 18 22:05:22 2010 -# by: PyQt4 UI code generator 4.7 -# -# WARNING! All changes made in this file will be lost! +############################################################################### +# OpenLP - Open Source Lyrics Projection # +# --------------------------------------------------------------------------- # +# Copyright (c) 2008-2010 Raoul Snyman # +# Portions copyright (c) 2008-2010 Tim Bentley, Jonathan Corwin, Michael # +# Gorven, Scott Guerrieri, Maikel Stuivenberg, Martin Thompson, Jon Tibble, # +# Carsten Tinggaard # +# --------------------------------------------------------------------------- # +# 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 PyQt4 import QtCore, QtGui class Ui_ServiceItemEditDialog(object): def setupUi(self, ServiceItemEditDialog): - ServiceItemEditDialog.setObjectName("ServiceItemEditDialog") + ServiceItemEditDialog.setObjectName(u'ServiceItemEditDialog') ServiceItemEditDialog.resize(386, 272) self.layoutWidget = QtGui.QWidget(ServiceItemEditDialog) self.layoutWidget.setGeometry(QtCore.QRect(20, 20, 351, 241)) - self.layoutWidget.setObjectName("layoutWidget") + self.layoutWidget.setObjectName(u'layoutWidget') self.outerLayout = QtGui.QVBoxLayout(self.layoutWidget) - self.outerLayout.setObjectName("outerLayout") + self.outerLayout.setObjectName(u'outerLayout') self.topLayout = QtGui.QHBoxLayout() - self.topLayout.setObjectName("topLayout") + self.topLayout.setObjectName(u'topLayout') self.listWidget = QtGui.QListWidget(self.layoutWidget) self.listWidget.setAlternatingRowColors(True) - self.listWidget.setObjectName("listWidget") + self.listWidget.setObjectName(u'listWidget') self.topLayout.addWidget(self.listWidget) self.buttonLayout = QtGui.QVBoxLayout() - self.buttonLayout.setObjectName("buttonLayout") + self.buttonLayout.setObjectName(u'buttonLayout') self.upButton = QtGui.QPushButton(self.layoutWidget) - self.upButton.setObjectName("upButton") + self.upButton.setObjectName(u'upButton') self.buttonLayout.addWidget(self.upButton) - spacerItem = QtGui.QSpacerItem(20, 40, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding) + spacerItem = QtGui.QSpacerItem(20, 40, + QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding) self.buttonLayout.addItem(spacerItem) self.deleteButton = QtGui.QPushButton(self.layoutWidget) - self.deleteButton.setObjectName("deleteButton") + self.deleteButton.setObjectName(u'deleteButton') self.buttonLayout.addWidget(self.deleteButton) self.downButton = QtGui.QPushButton(self.layoutWidget) - self.downButton.setObjectName("downButton") + self.downButton.setObjectName(u'downButton') self.buttonLayout.addWidget(self.downButton) self.topLayout.addLayout(self.buttonLayout) self.outerLayout.addLayout(self.topLayout) self.buttonBox = QtGui.QDialogButtonBox(self.layoutWidget) - self.buttonBox.setStandardButtons(QtGui.QDialogButtonBox.Cancel|QtGui.QDialogButtonBox.Save) - self.buttonBox.setObjectName("buttonBox") + self.buttonBox.setStandardButtons( + QtGui.QDialogButtonBox.Cancel|QtGui.QDialogButtonBox.Save) + self.buttonBox.setObjectName(u'buttonBox') self.outerLayout.addWidget(self.buttonBox) self.retranslateUi(ServiceItemEditDialog) QtCore.QMetaObject.connectSlotsByName(ServiceItemEditDialog) def retranslateUi(self, ServiceItemEditDialog): - ServiceItemEditDialog.setWindowTitle(QtGui.QApplication.translate("ServiceItemEditDialog", "Service Item Maintenance", None, QtGui.QApplication.UnicodeUTF8)) - self.upButton.setText(QtGui.QApplication.translate("ServiceItemEditDialog", "Up", None, QtGui.QApplication.UnicodeUTF8)) - self.deleteButton.setText(QtGui.QApplication.translate("ServiceItemEditDialog", "Delete", None, QtGui.QApplication.UnicodeUTF8)) - self.downButton.setText(QtGui.QApplication.translate("ServiceItemEditDialog", "Down", None, QtGui.QApplication.UnicodeUTF8)) + ServiceItemEditDialog.setWindowTitle(self.trUtf8('Service Item Maintenance')) + self.upButton.setText(self.trUtf8('Up')) + self.deleteButton.setText(self.trUtf8('Delete')) + self.downButton.setText(self.trUtf8('Down')) diff --git a/openlp/core/ui/serviceitemeditform.py b/openlp/core/ui/serviceitemeditform.py index cbe530d80..4293e15c8 100644 --- a/openlp/core/ui/serviceitemeditform.py +++ b/openlp/core/ui/serviceitemeditform.py @@ -81,20 +81,17 @@ class ServiceItemEditForm(QtGui.QDialog, Ui_ServiceItemEditDialog): def onItemDelete(self): """ - Move the current ServiceItem up in the list - Note move up means move to top of area ie 0. + Delete the selected row """ items = self.listWidget.selectedItems() for item in items: row = self.listWidget.row(item) - if row > 0: - self.itemList.remove(self.itemList[row]) - self.loadData() + self.itemList.remove(self.itemList[row]) + self.loadData() def onItemUp(self): """ - Move the current ServiceItem up in the list - Note move up means move to top of area ie 0. + Move the selected row up in the list """ items = self.listWidget.selectedItems() for item in items: @@ -107,8 +104,7 @@ class ServiceItemEditForm(QtGui.QDialog, Ui_ServiceItemEditDialog): def onItemDown(self): """ - Move the current ServiceItem down in the list - Note move down means move to bottom of area i.e len(). + Move the selected row down in the list """ items = self.listWidget.selectedItems() for item in items: From 92d39b1d98a605094b5fc7c76efe41a517bbf84a Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sat, 20 Mar 2010 08:34:36 +0000 Subject: [PATCH 11/30] Minor tidy ups and add stupidity block --- openlp/core/lib/mediamanageritem.py | 11 +++++++++-- openlp/core/ui/servicemanager.py | 1 + 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/openlp/core/lib/mediamanageritem.py b/openlp/core/lib/mediamanageritem.py index 241a534f7..5dd0ee97f 100644 --- a/openlp/core/lib/mediamanageritem.py +++ b/openlp/core/lib/mediamanageritem.py @@ -290,7 +290,8 @@ class MediaManagerItem(QtGui.QWidget): self.ListView.addAction( contextMenuAction( self.ListView, u':/system/system_add.png', - self.trUtf8('&Add to Service Item'), self.onAddEditClick)) + self.trUtf8('&Add to selected Service Item'), + self.onAddEditClick)) QtCore.QObject.connect( self.ListView, QtCore.SIGNAL(u'doubleClicked(QModelIndex)'), self.onPreviewClick) @@ -404,9 +405,15 @@ class MediaManagerItem(QtGui.QWidget): QtGui.QMessageBox.information(self, self.trUtf8('No Servive item selected'), self.trUtf8('You must select a existing Service Item to add to.')) - else: + elif self.title == service_item.name: self.generateSlideData(service_item) self.parent.service_manager.addServiceItem(service_item) + else: + #Turn off the remote edit update message indicator + self.parent.service_manager.remoteEditTriggered = False + QtGui.QMessageBox.information(self, + self.trUtf8('Invalid Service Item'), + self.trUtf8(unicode('You must select a %s service item.' % self.title))) def buildServiceItem(self): """ diff --git a/openlp/core/ui/servicemanager.py b/openlp/core/ui/servicemanager.py index 3225d9237..78d639ae2 100644 --- a/openlp/core/ui/servicemanager.py +++ b/openlp/core/ui/servicemanager.py @@ -691,6 +691,7 @@ class ServiceManager(QtGui.QWidget): if item == -1: return False else: + #Switch on remote edit update functionality. self.remoteEditTriggered = True return self.serviceItems[item][u'service_item'] From 2ff005cdc050dafc8e4d6e33b14ec31cfa1a5782 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sun, 21 Mar 2010 19:55:51 +0000 Subject: [PATCH 12/30] Add verse tag to live song rows --- openlp/core/ui/slidecontroller.py | 34 ++++++++++++++++++++++--------- 1 file changed, 24 insertions(+), 10 deletions(-) diff --git a/openlp/core/ui/slidecontroller.py b/openlp/core/ui/slidecontroller.py index 0af64819a..391ff7461 100644 --- a/openlp/core/ui/slidecontroller.py +++ b/openlp/core/ui/slidecontroller.py @@ -94,6 +94,10 @@ class SlideController(QtGui.QWidget): self.song_edit_list = [ u'Edit Song', ] + if isLive: + self.labelWidth = 20 + else: + self.labelWidth = 0 self.timer_id = 0 self.songEdit = False self.selectedRow = 0 @@ -133,10 +137,11 @@ class SlideController(QtGui.QWidget): self.ControllerLayout.setMargin(0) # Controller list view self.PreviewListWidget = SlideList(self) - self.PreviewListWidget.setColumnCount(1) + self.PreviewListWidget.setColumnCount(2) self.PreviewListWidget.horizontalHeader().setVisible(False) self.PreviewListWidget.verticalHeader().setVisible(False) - self.PreviewListWidget.setColumnWidth(1, self.Controller.width()) + self.PreviewListWidget.setColumnWidth(1, self.labelWidth) + self.PreviewListWidget.setColumnWidth(1, self.Controller.width() - self.labelWidth) self.PreviewListWidget.isLive = self.isLive self.PreviewListWidget.setObjectName(u'PreviewListWidget') self.PreviewListWidget.setEditTriggers( @@ -309,7 +314,8 @@ class SlideController(QtGui.QWidget): """ width = self.parent.ControlSplitter.sizes()[self.split] height = width * self.parent.RenderManager.screen_ratio - self.PreviewListWidget.setColumnWidth(0, width) + self.PreviewListWidget.setColumnWidth(0, self.labelWidth) + self.PreviewListWidget.setColumnWidth(1, width - self.labelWidth) #Sort out image hights (Songs , bibles excluded) if self.serviceItem and not self.serviceItem.is_text(): for framenumber, frame in enumerate(self.serviceItem.get_frames()): @@ -448,14 +454,17 @@ class SlideController(QtGui.QWidget): self.serviceItem = serviceItem self.PreviewListWidget.clear() self.PreviewListWidget.setRowCount(0) - self.PreviewListWidget.setColumnWidth(0, width) + self.PreviewListWidget.setColumnWidth(1, self.labelWidth) + self.PreviewListWidget.setColumnWidth(1, width - self.labelWidth) if self.isLive: self.SongMenu.menu().clear() for framenumber, frame in enumerate(self.serviceItem.get_frames()): self.PreviewListWidget.setRowCount( self.PreviewListWidget.rowCount() + 1) + rowitem = QtGui.QTableWidgetItem() item = QtGui.QTableWidgetItem() slide_height = 0 + row = u'' #It is a based Text Render if self.serviceItem.is_text(): if self.isLive and frame[u'verseTag'] is not None: @@ -484,15 +493,18 @@ class SlideController(QtGui.QWidget): self.parent.RenderManager.height) label.setScaledContents(True) label.setPixmap(QtGui.QPixmap.fromImage(pixmap)) - self.PreviewListWidget.setCellWidget(framenumber, 0, label) + self.PreviewListWidget.setCellWidget(framenumber, 1, label) slide_height = width * self.parent.RenderManager.screen_ratio - self.PreviewListWidget.setItem(framenumber, 0, item) + rowitem.setText(row) + self.PreviewListWidget.setItem(framenumber, 0, rowitem) + self.PreviewListWidget.setItem(framenumber, 1, item) if slide_height != 0: self.PreviewListWidget.setRowHeight(framenumber, slide_height) if self.serviceItem.is_text(): self.PreviewListWidget.resizeRowsToContents() - self.PreviewListWidget.setColumnWidth( - 0, self.PreviewListWidget.viewport().size().width()) + self.PreviewListWidget.setColumnWidth(0, self.labelWidth) + self.PreviewListWidget.setColumnWidth(1, + self.PreviewListWidget.viewport().size().width() - self.labelWidth ) if slideno > self.PreviewListWidget.rowCount(): self.PreviewListWidget.selectRow(self.PreviewListWidget.rowCount()) else: @@ -549,6 +561,7 @@ class SlideController(QtGui.QWidget): if this is the Live Controller also display on the screen """ row = self.PreviewListWidget.currentRow() + self.PreviewListWidget.selectRow(row) self.selectedRow = 0 if row > -1 and row < self.PreviewListWidget.rowCount(): if self.serviceItem.is_command() and self.isLive: @@ -585,7 +598,7 @@ class SlideController(QtGui.QWidget): QtCore.QTimer.singleShot(2.5, self.grabMainDisplay) else: label = self.PreviewListWidget.cellWidget( - self.PreviewListWidget.currentRow(), 0) + self.PreviewListWidget.currentRow(), 1) self.SlidePreview.setPixmap(label.pixmap()) def grabMainDisplay(self): @@ -654,7 +667,8 @@ class SlideController(QtGui.QWidget): self.serviceItem.name.lower(), self.isLive) self.updatePreview() else: - self.PreviewListWidget.selectRow(self.PreviewListWidget.rowCount() - 1) + self.PreviewListWidget.selectRow( + self.PreviewListWidget.rowCount() - 1) self.onSlideSelected() def onStartLoop(self): From 32086cb87731412b7276c2a85e5042772ff39af2 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Mon, 22 Mar 2010 18:31:43 +0000 Subject: [PATCH 13/30] Fix slide selection so looks nice --- openlp/core/ui/slidecontroller.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/openlp/core/ui/slidecontroller.py b/openlp/core/ui/slidecontroller.py index 391ff7461..1b123f2e2 100644 --- a/openlp/core/ui/slidecontroller.py +++ b/openlp/core/ui/slidecontroller.py @@ -144,6 +144,7 @@ class SlideController(QtGui.QWidget): self.PreviewListWidget.setColumnWidth(1, self.Controller.width() - self.labelWidth) self.PreviewListWidget.isLive = self.isLive self.PreviewListWidget.setObjectName(u'PreviewListWidget') + self.PreviewListWidget.setSelectionBehavior(1) self.PreviewListWidget.setEditTriggers( QtGui.QAbstractItemView.NoEditTriggers) self.PreviewListWidget.setHorizontalScrollBarPolicy(QtCore.Qt.ScrollBarAlwaysOff) @@ -561,7 +562,6 @@ class SlideController(QtGui.QWidget): if this is the Live Controller also display on the screen """ row = self.PreviewListWidget.currentRow() - self.PreviewListWidget.selectRow(row) self.selectedRow = 0 if row > -1 and row < self.PreviewListWidget.rowCount(): if self.serviceItem.is_command() and self.isLive: From f158044d5e9fa8ad5c36ecbbe92d06a535eb7b98 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Wed, 24 Mar 2010 19:05:45 +0000 Subject: [PATCH 14/30] Fix row counts and bad code before superfly spots it --- openlp/core/ui/slidecontroller.py | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/openlp/core/ui/slidecontroller.py b/openlp/core/ui/slidecontroller.py index 34a29372a..3a02e2e40 100644 --- a/openlp/core/ui/slidecontroller.py +++ b/openlp/core/ui/slidecontroller.py @@ -460,17 +460,17 @@ class SlideController(QtGui.QWidget): self.serviceItem = serviceItem self.PreviewListWidget.clear() self.PreviewListWidget.setRowCount(0) - self.PreviewListWidget.setColumnWidth(1, self.labelWidth) + self.PreviewListWidget.setColumnWidth(0, self.labelWidth) self.PreviewListWidget.setColumnWidth(1, width - self.labelWidth) if self.isLive: self.SongMenu.menu().clear() + row = 0 for framenumber, frame in enumerate(self.serviceItem.get_frames()): self.PreviewListWidget.setRowCount( self.PreviewListWidget.rowCount() + 1) rowitem = QtGui.QTableWidgetItem() item = QtGui.QTableWidgetItem() slide_height = 0 - row = u'' #It is a based Text Render if self.serviceItem.is_text(): if self.isLive and frame[u'verseTag'] is not None: @@ -484,12 +484,12 @@ class SlideController(QtGui.QWidget): else: tag = bits[0] row = bits[0][0:1] - try: - test = self.slideList[tag] - except: + if tag not in self.slideList: self.slideList[tag] = framenumber self.SongMenu.menu().addAction(self.trUtf8(u'%s'%tag), self.onSongBarHandler) + else: + row += 1 item.setText(frame[u'text']) else: label = QtGui.QLabel() @@ -501,7 +501,7 @@ class SlideController(QtGui.QWidget): label.setPixmap(QtGui.QPixmap.fromImage(pixmap)) self.PreviewListWidget.setCellWidget(framenumber, 1, label) slide_height = width * self.parent.RenderManager.screen_ratio - rowitem.setText(row) + rowitem.setText(unicode(row)) self.PreviewListWidget.setItem(framenumber, 0, rowitem) self.PreviewListWidget.setItem(framenumber, 1, item) if slide_height != 0: From 59dd69eee17cdf4119c88b571a629c83926d53a2 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Wed, 24 Mar 2010 19:10:08 +0000 Subject: [PATCH 15/30] Do not display empty list --- openlp/core/ui/slidecontroller.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/openlp/core/ui/slidecontroller.py b/openlp/core/ui/slidecontroller.py index 3a02e2e40..498fce9b3 100644 --- a/openlp/core/ui/slidecontroller.py +++ b/openlp/core/ui/slidecontroller.py @@ -361,7 +361,8 @@ class SlideController(QtGui.QWidget): if item.is_text(): self.Toolbar.makeWidgetsInvisible(self.image_list) if item.is_song() and \ - str_to_bool(self.songsconfig.get_config(u'show songbar', True)): + str_to_bool(self.songsconfig.get_config(u'show songbar', True)) \ + and len(self.slideList) > 0: self.Toolbar.makeWidgetsVisible([u'Song Menu']) elif item.is_image(): #Not sensible to allow loops with 1 frame From b20c29f45cfc7d5df42c45c9740280b02adf6295 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Thu, 25 Mar 2010 18:52:16 +0000 Subject: [PATCH 16/30] Add delete to context menu --- openlp/core/lib/mediamanageritem.py | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/openlp/core/lib/mediamanageritem.py b/openlp/core/lib/mediamanageritem.py index 087d5a25d..58a50557f 100644 --- a/openlp/core/lib/mediamanageritem.py +++ b/openlp/core/lib/mediamanageritem.py @@ -280,6 +280,13 @@ class MediaManagerItem(QtGui.QWidget): u'%s %s' % (self.trUtf8('&Edit'), self.PluginNameVisible), self.onEditClick)) self.ListView.addAction(contextMenuSeparator(self.ListView)) + if self.hasDeleteIcon: + self.ListView.addAction( + contextMenuAction( + self.ListView, u':/general/general_delete.png', + u'%s %s' % (self.trUtf8('&Delete'), self.PluginNameVisible), + self.onDeleteClick)) + self.ListView.addAction(contextMenuSeparator(self.ListView)) self.ListView.addAction( contextMenuAction( self.ListView, u':/general/general_preview.png', From 63aa5839428ffeead5bd2610ec1ab777fd70d188 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Thu, 25 Mar 2010 20:01:15 +0000 Subject: [PATCH 17/30] Images bulk delete if selected --- openlp/plugins/images/lib/mediaitem.py | 21 +++++++++++---------- 1 file changed, 11 insertions(+), 10 deletions(-) diff --git a/openlp/plugins/images/lib/mediaitem.py b/openlp/plugins/images/lib/mediaitem.py index cd8302407..dbb3e3f2d 100644 --- a/openlp/plugins/images/lib/mediaitem.py +++ b/openlp/plugins/images/lib/mediaitem.py @@ -114,16 +114,17 @@ class ImageMediaItem(MediaManagerItem): self.toggleOverrideState) def onDeleteClick(self): - item = self.ListView.currentItem() - if item: - try: - os.remove(os.path.join(self.servicePath, unicode(item.text()))) - except: - #if not present do not worry - pass - row = self.ListView.row(item) - self.ListView.takeItem(row) - self.parent.config.set_list(self.ConfigSection, self.getFileList()) + items = self.ListView.selectedIndexes() + if items: + for item in items: + text = self.ListView.item(item.row()) + try: + os.remove(os.path.join(self.servicePath, unicode(text.text()))) + except: + #if not present do not worry + pass + self.ListView.takeItem(item.row()) + self.parent.config.set_list(self.ConfigSection, self.getFileList()) def loadList(self, list): for file in list: From 463847c61c4bf9d5d0d91336018abbadb8ed719c Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Thu, 25 Mar 2010 20:24:52 +0000 Subject: [PATCH 18/30] Correct image override process --- openlp/core/ui/slidecontroller.py | 6 +++ openlp/plugins/images/lib/mediaitem.py | 51 +++++++------------------- 2 files changed, 20 insertions(+), 37 deletions(-) diff --git a/openlp/core/ui/slidecontroller.py b/openlp/core/ui/slidecontroller.py index 498fce9b3..ac4addfc7 100644 --- a/openlp/core/ui/slidecontroller.py +++ b/openlp/core/ui/slidecontroller.py @@ -178,6 +178,12 @@ class SlideController(QtGui.QWidget): self.blankButton = self.Toolbar.addToolbarButton( u'Blank Screen', u':/slides/slide_blank.png', self.trUtf8('Blank Screen'), self.onBlankDisplay, True) + self.themeButton = self.Toolbar.addToolbarButton( + u'Display Theme', u':/slides/slide_theme.png', + self.trUtf8('Blank Screen'), self.onBlankDisplay, True) + self.hideButton = self.Toolbar.addToolbarButton( + u'Hide screen', u':/slides/slide_desktop.png', + self.trUtf8('Blank Screen'), self.onBlankDisplay, True) QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'live_slide_blank'), self.blankScreen) if not self.isLive: diff --git a/openlp/plugins/images/lib/mediaitem.py b/openlp/plugins/images/lib/mediaitem.py index dbb3e3f2d..c3f2ce699 100644 --- a/openlp/plugins/images/lib/mediaitem.py +++ b/openlp/plugins/images/lib/mediaitem.py @@ -54,7 +54,6 @@ class ImageMediaItem(MediaManagerItem): self.servicePath = None self.addToServiceItem = True MediaManagerItem.__init__(self, parent, icon, title) - self.overrideActive = False def initPluginNameVisible(self): self.PluginNameVisible = self.trUtf8('Image') @@ -92,26 +91,11 @@ class ImageMediaItem(MediaManagerItem): self.ImageWidget.sizePolicy().hasHeightForWidth()) self.ImageWidget.setSizePolicy(sizePolicy) self.ImageWidget.setObjectName(u'ImageWidget') - self.OverrideLayout = QtGui.QVBoxLayout(self.ImageWidget) - self.OverrideLayout.setMargin(5) - self.OverrideLayout.setSpacing(4) - self.OverrideLayout.setObjectName(u'OverrideLayout') - self.OverrideCheckBox = QtGui.QCheckBox(self.ImageWidget) - self.OverrideCheckBox.setObjectName(u'OverrideCheckBox') - self.OverrideCheckBox.setCheckable(True) - self.OverrideCheckBox.setChecked(False) - self.OverrideCheckBox.setText(self.trUtf8('Override background')) - self.OverrideCheckBox.setStatusTip( - self.trUtf8('Allow the background of live slide to be overridden')) - self.OverrideLayout.addWidget(self.OverrideCheckBox) - self.OverrideLabel = QtGui.QLabel(self.ImageWidget) - self.OverrideLabel.setObjectName(u'OverrideLabel') - self.OverrideLayout.addWidget(self.OverrideLabel) + self.blankButton = self.Toolbar.addToolbarButton( + u'Replace Background', u':/slides/slide_blank.png', + self.trUtf8('Replace Background'), self.onReplaceClick, False) # Add the song widget to the page layout self.PageLayout.addWidget(self.ImageWidget) - QtCore.QObject.connect(self.OverrideCheckBox, - QtCore.SIGNAL(u'stateChanged(int)'), - self.toggleOverrideState) def onDeleteClick(self): items = self.ListView.selectedIndexes() @@ -158,24 +142,17 @@ class ImageMediaItem(MediaManagerItem): else: return False - def toggleOverrideState(self): - self.overrideActive = not self.overrideActive - if not self.overrideActive: - self.OverrideLabel.setText(u'') - self.parent.render_manager.override_background = None + def onReplaceClick(self): + if not self.ListView.selectedIndexes(): + QtGui.QMessageBox.information(self, + self.trUtf8('No item selected...'), + self.trUtf8('You must select one item')) + items = self.ListView.selectedIndexes() + for item in items: + bitem = self.ListView.item(item.row()) + filename = unicode((bitem.data(QtCore.Qt.UserRole)).toString()) + frame = QtGui.QImage(unicode(filename)) + self.parent.maindisplay.addImageWithText(frame) def onPreviewClick(self): - if self.overrideActive: - if not self.ListView.selectedIndexes(): - QtGui.QMessageBox.information(self, - self.trUtf8('No items selected...'), - self.trUtf8('You must select one or more items')) - items = self.ListView.selectedIndexes() - for item in items: - bitem = self.ListView.item(item.row()) - filename = unicode((bitem.data(QtCore.Qt.UserRole)).toString()) - self.OverrideLabel.setText(bitem.text()) - frame = QtGui.QImage(unicode(filename)) - self.parent.maindisplay.addImageWithText(frame) - else: MediaManagerItem.onPreviewClick(self) From e4db12423a852f6f2deb86ce0ee8c673b6e6daf7 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Thu, 25 Mar 2010 21:53:52 +0000 Subject: [PATCH 19/30] Add Theme and Hide buttons to slide controller --- openlp/core/ui/__init__.py | 1 + openlp/core/ui/maindisplay.py | 13 +++++++--- openlp/core/ui/slidecontroller.py | 42 ++++++++++++++++++++++++++----- 3 files changed, 47 insertions(+), 9 deletions(-) diff --git a/openlp/core/ui/__init__.py b/openlp/core/ui/__init__.py index 54f2d31e1..b46ea769b 100644 --- a/openlp/core/ui/__init__.py +++ b/openlp/core/ui/__init__.py @@ -23,6 +23,7 @@ # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### +from slidecontroller import DisplayHideMode from servicenoteform import ServiceNoteForm from serviceitemeditform import ServiceItemEditForm from screen import ScreenList diff --git a/openlp/core/ui/maindisplay.py b/openlp/core/ui/maindisplay.py index f16b3b455..03cd9d830 100644 --- a/openlp/core/ui/maindisplay.py +++ b/openlp/core/ui/maindisplay.py @@ -30,6 +30,7 @@ from PyQt4 import QtCore, QtGui from PyQt4.phonon import Phonon from openlp.core.lib import Receiver, resize_image +from openlp.core.ui import DisplayHideMode log = logging.getLogger(__name__) @@ -253,11 +254,17 @@ class MainDisplay(DisplayWidget): self.waitingFrame = frame self.waitingFrameTrans = transition - def blankDisplay(self, blanked=True): + def blankDisplay(self, blankType=DisplayHideMode.Blank, blanked=True): log.debug(u'Blank main Display %d' % blanked) if blanked: self.displayBlank = True - self.display_text.setPixmap(QtGui.QPixmap.fromImage(self.blankFrame)) + if blankType == DisplayHideMode.Blank: + self.display_text.setPixmap(QtGui.QPixmap.fromImage(self.blankFrame)) + elif blankType == DisplayHideMode.Theme: + theme = self.parent.RenderManager.renderer.bg_frame + if not theme: + theme = self.blankFrame + self.display_text.setPixmap(QtGui.QPixmap.fromImage(theme)) self.waitingFrame = None self.waitingFrameTrans = False else: @@ -313,4 +320,4 @@ class MainDisplay(DisplayWidget): self.video.setVisible(False) self.display_text.show() self.display_image.show() - self.blankDisplay(False) + self.blankDisplay(False, False) diff --git a/openlp/core/ui/slidecontroller.py b/openlp/core/ui/slidecontroller.py index ac4addfc7..a4fb4ef01 100644 --- a/openlp/core/ui/slidecontroller.py +++ b/openlp/core/ui/slidecontroller.py @@ -30,6 +30,15 @@ import os from PyQt4 import QtCore, QtGui from PyQt4.phonon import Phonon +class DisplayHideMode(object): + """ + This is basically an enumeration class which specifies the mode of a Bible. + Mode refers to whether or not a Bible in OpenLP is a full Bible or needs to + be downloaded from the Internet on an as-needed basis. + """ + Blank = 1 + Theme = 2 + from openlp.core.lib import OpenLPToolbar, Receiver, str_to_bool, \ PluginConfig, resize_image @@ -180,10 +189,10 @@ class SlideController(QtGui.QWidget): self.trUtf8('Blank Screen'), self.onBlankDisplay, True) self.themeButton = self.Toolbar.addToolbarButton( u'Display Theme', u':/slides/slide_theme.png', - self.trUtf8('Blank Screen'), self.onBlankDisplay, True) + self.trUtf8('Theme Screen'), self.onThemeDisplay, True) self.hideButton = self.Toolbar.addToolbarButton( u'Hide screen', u':/slides/slide_desktop.png', - self.trUtf8('Blank Screen'), self.onBlankDisplay, True) + self.trUtf8('Hide Screen'), self.onHideDisplay, True) QtCore.QObject.connect(Receiver.get_receiver(), QtCore.SIGNAL(u'live_slide_blank'), self.blankScreen) if not self.isLive: @@ -551,11 +560,32 @@ class SlideController(QtGui.QWidget): log.debug(u'onBlankDisplay %d' % force) if force: self.blankButton.setChecked(True) - self.blankScreen(self.blankButton.isChecked()) + self.blankScreen(DisplayHideMode.Blank, self.blankButton.isChecked()) self.parent.generalConfig.set_config(u'screen blank', self.blankButton.isChecked()) - def blankScreen(self, blanked=False): + def onThemeDisplay(self, force=False): + """ + Handle the Theme screen button + """ + log.debug(u'onThemeDisplay %d' % force) + if force: + self.themeButton.setChecked(True) + self.blankScreen(DisplayHideMode.Theme, self.themeButton.isChecked()) + + def onHideDisplay(self, force=False): + """ + Handle the Hide screen button + """ + log.debug(u'onHideDisplay %d' % force) + if force: + self.themeButton.setChecked(True) + if self.hideButton.isChecked(): + self.parent.mainDisplay.hide1Display() + else: + self.parent.mainDisplay.showDisplay() + + def blankScreen(self, blankType, blanked=False): """ Blank the display screen. """ @@ -566,9 +596,9 @@ class SlideController(QtGui.QWidget): else: Receiver.send_message(u'%s_unblank'% self.serviceItem.name.lower()) else: - self.parent.mainDisplay.blankDisplay(blanked) + self.parent.mainDisplay.blankDisplay(blankType, blanked) else: - self.parent.mainDisplay.blankDisplay(blanked) + self.parent.mainDisplay.blankDisplay(blankType, blanked) def onSlideSelected(self): """ From 92e90b91e5c8d3f0f02ea637d4574a12534e4c29 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Fri, 26 Mar 2010 20:20:09 +0000 Subject: [PATCH 20/30] Fixes and cleanups --- openlp/core/lib/mediamanageritem.py | 4 ++-- openlp/core/ui/slidecontroller.py | 2 +- openlp/plugins/bibles/lib/mediaitem.py | 1 + openlp/plugins/images/lib/mediaitem.py | 18 ++++++++++++++---- 4 files changed, 18 insertions(+), 7 deletions(-) diff --git a/openlp/core/lib/mediamanageritem.py b/openlp/core/lib/mediamanageritem.py index 58a50557f..7d410c10f 100644 --- a/openlp/core/lib/mediamanageritem.py +++ b/openlp/core/lib/mediamanageritem.py @@ -114,7 +114,7 @@ class MediaManagerItem(QtGui.QWidget): self.Toolbar = None self.remoteTriggered = None self.ServiceItemIconName = None - self.addToServiceItem = True + self.addToServiceItem = False self.PageLayout = QtGui.QVBoxLayout(self) self.PageLayout.setSpacing(0) self.PageLayout.setContentsMargins(4, 0, 4, 0) @@ -303,7 +303,7 @@ class MediaManagerItem(QtGui.QWidget): if self.addToServiceItem: self.ListView.addAction( contextMenuAction( - self.ListView, u':/system/system_add.png', + self.ListView, u':/general/general_add.png', self.trUtf8('&Add to selected Service Item'), self.onAddEditClick)) QtCore.QObject.connect( diff --git a/openlp/core/ui/slidecontroller.py b/openlp/core/ui/slidecontroller.py index a4fb4ef01..92f383c57 100644 --- a/openlp/core/ui/slidecontroller.py +++ b/openlp/core/ui/slidecontroller.py @@ -581,7 +581,7 @@ class SlideController(QtGui.QWidget): if force: self.themeButton.setChecked(True) if self.hideButton.isChecked(): - self.parent.mainDisplay.hide1Display() + self.parent.mainDisplay.hideDisplay() else: self.parent.mainDisplay.showDisplay() diff --git a/openlp/plugins/bibles/lib/mediaitem.py b/openlp/plugins/bibles/lib/mediaitem.py index 070ba6529..f550b6e36 100644 --- a/openlp/plugins/bibles/lib/mediaitem.py +++ b/openlp/plugins/bibles/lib/mediaitem.py @@ -81,6 +81,7 @@ class BibleMediaItem(MediaManagerItem): self.hasNewIcon = False self.hasEditIcon = False self.hasDeleteIcon = False + self.addToServiceItem = True def addEndHeaderBar(self): self.SearchTabWidget = QtGui.QTabWidget(self) diff --git a/openlp/plugins/images/lib/mediaitem.py b/openlp/plugins/images/lib/mediaitem.py index c3f2ce699..73c61df40 100644 --- a/openlp/plugins/images/lib/mediaitem.py +++ b/openlp/plugins/images/lib/mediaitem.py @@ -27,7 +27,8 @@ import logging import os from PyQt4 import QtCore, QtGui -from openlp.core.lib import MediaManagerItem, BaseListWithDnD, build_icon +from openlp.core.lib import MediaManagerItem, BaseListWithDnD, build_icon, \ +contextMenuAction, contextMenuSeparator log = logging.getLogger(__name__) @@ -52,7 +53,6 @@ class ImageMediaItem(MediaManagerItem): # be instanced by the base MediaManagerItem self.ListViewWithDnD_class = ImageListView self.servicePath = None - self.addToServiceItem = True MediaManagerItem.__init__(self, parent, icon, title) def initPluginNameVisible(self): @@ -68,6 +68,7 @@ class ImageMediaItem(MediaManagerItem): self.hasFileIcon = True self.hasNewIcon = False self.hasEditIcon = False + self.addToServiceItem = True def initialise(self): log.debug(u'initialise') @@ -81,6 +82,15 @@ class ImageMediaItem(MediaManagerItem): os.mkdir(self.servicePath) self.loadList(self.parent.config.load_list(self.ConfigSection)) + def addListViewToToolBar(self): + MediaManagerItem.addListViewToToolBar(self) + self.ListView.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu) + self.ListView.addAction( + contextMenuAction( + self.ListView, u':/slides/slide_blank.png', + self.trUtf8('Replace Live Background'), + self.onReplaceClick)) + def addEndHeaderBar(self): self.ImageWidget = QtGui.QWidget(self) sizePolicy = QtGui.QSizePolicy( @@ -93,7 +103,7 @@ class ImageMediaItem(MediaManagerItem): self.ImageWidget.setObjectName(u'ImageWidget') self.blankButton = self.Toolbar.addToolbarButton( u'Replace Background', u':/slides/slide_blank.png', - self.trUtf8('Replace Background'), self.onReplaceClick, False) + self.trUtf8('Replace Live Background'), self.onReplaceClick, False) # Add the song widget to the page layout self.PageLayout.addWidget(self.ImageWidget) @@ -155,4 +165,4 @@ class ImageMediaItem(MediaManagerItem): self.parent.maindisplay.addImageWithText(frame) def onPreviewClick(self): - MediaManagerItem.onPreviewClick(self) + MediaManagerItem.onPreviewClick(self) From 35255c250e60ccf0262d31873d0267656209e2b7 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Fri, 26 Mar 2010 20:48:46 +0000 Subject: [PATCH 21/30] Fix up theme bugs --- openlp/core/lib/renderer.py | 9 ++++----- openlp/core/ui/amendthemeform.py | 11 ++--------- 2 files changed, 6 insertions(+), 14 deletions(-) diff --git a/openlp/core/lib/renderer.py b/openlp/core/lib/renderer.py index 39fcf9aa7..99b4a7e6f 100644 --- a/openlp/core/lib/renderer.py +++ b/openlp/core/lib/renderer.py @@ -466,8 +466,7 @@ class Renderer(object): tlcorner=(x + display_shadow_size, y + display_shadow_size), draw=True, color = self._theme.display_shadow_color) self._get_extent_and_render(line, footer, tlcorner=(x, y), draw=True, - outline_size=display_outline_size, - outline_color=self._theme.display_outline_color) + outline_size=display_outline_size) y += h if linenum == 0: self._first_line_right_extent = rightextent @@ -505,7 +504,7 @@ class Renderer(object): self.mainFont.setPixelSize(self._theme.font_main_proportion) def _get_extent_and_render(self, line, footer, tlcorner=(0, 0), draw=False, - color=None, outline_size=0, outline_color=None): + color=None, outline_size=0): """ Find bounding box of text - as render_single_line. If draw is set, actually draw the text to the current DC as well return width and @@ -544,7 +543,7 @@ class Renderer(object): else: pen = QtGui.QColor(color) x, y = tlcorner - if self._theme.display_outline: + if self._theme.display_outline and outline_size != 0: path = QtGui.QPainterPath() path.addText(QtCore.QPointF(x, y + metrics.ascent()), font, line) self.painter.setBrush(self.painter.pen().brush()) @@ -555,7 +554,7 @@ class Renderer(object): self.painter.drawText(x, y + metrics.ascent(), line) if self._theme.display_slideTransition: # Print 2nd image with 70% weight - if self._theme.display_outline: + if self._theme.display_outline and outline_size != 0: path = QtGui.QPainterPath() path.addText(QtCore.QPointF(x, y + metrics.ascent()), font, line) self.painter2.setBrush(self.painter2.pen().brush()) diff --git a/openlp/core/ui/amendthemeform.py b/openlp/core/ui/amendthemeform.py index 97ae9858b..03c2df3f5 100644 --- a/openlp/core/ui/amendthemeform.py +++ b/openlp/core/ui/amendthemeform.py @@ -393,6 +393,7 @@ class AmendThemeForm(QtGui.QDialog, Ui_AmendThemeDialog): self.theme.background_type = u'solid' if self.theme.background_color is None : self.theme.background_color = u'#000000' + self.ImageLineEdit.setText(u'') elif background == 1: # Gradient self.theme.background_type = u'gradient' if gradient == 0: # Horizontal @@ -405,6 +406,7 @@ class AmendThemeForm(QtGui.QDialog, Ui_AmendThemeDialog): self.theme.background_startColor = u'#000000' if self.theme.background_endColor is None : self.theme.background_endColor = u'#ff0000' + self.ImageLineEdit.setText(u'') else: self.theme.background_type = u'image' self.stateChanging(self.theme) @@ -422,7 +424,6 @@ class AmendThemeForm(QtGui.QDialog, Ui_AmendThemeDialog): self.Color1PushButton.setStyleSheet( u'background-color: %s' % \ unicode(self.theme.background_startColor)) - self.previewTheme() def onColor2PushButtonClicked(self): @@ -561,22 +562,18 @@ class AmendThemeForm(QtGui.QDialog, Ui_AmendThemeDialog): u'background-color: %s' % unicode(theme.font_main_color)) self.FontFooterColorPushButton.setStyleSheet( u'background-color: %s' % unicode(theme.font_footer_color)) - if not self.theme.font_main_override: self.FontMainDefaultCheckBox.setChecked(True) else: self.FontMainDefaultCheckBox.setChecked(False) - if not self.theme.font_footer_override: self.FontFooterDefaultCheckBox.setChecked(True) else: self.FontFooterDefaultCheckBox.setChecked(False) - self.OutlineColorPushButton.setStyleSheet( u'background-color: %s' % unicode(theme.display_outline_color)) self.ShadowColorPushButton.setStyleSheet( u'background-color: %s' % unicode(theme.display_shadow_color)) - if self.theme.display_outline: self.OutlineCheckBox.setChecked(True) self.OutlineColorPushButton.setEnabled(True) @@ -584,7 +581,6 @@ class AmendThemeForm(QtGui.QDialog, Ui_AmendThemeDialog): self.OutlineCheckBox.setChecked(False) self.OutlineColorPushButton.setEnabled(False) self.OutlineSpinBox.setValue(int(self.theme.display_outline_size)) - if self.theme.display_shadow: self.ShadowCheckBox.setChecked(True) self.ShadowColorPushButton.setEnabled(True) @@ -592,12 +588,10 @@ class AmendThemeForm(QtGui.QDialog, Ui_AmendThemeDialog): self.ShadowCheckBox.setChecked(False) self.ShadowColorPushButton.setEnabled(False) self.ShadowSpinBox.setValue(int(self.theme.display_shadow_size)) - if self.theme.display_slideTransition: self.SlideTransitionCheckedBox.setCheckState(QtCore.Qt.Checked) else: self.SlideTransitionCheckedBox.setCheckState(QtCore.Qt.Unchecked) - self.HorizontalComboBox.setCurrentIndex( self.theme.display_horizontalAlign) self.VerticalComboBox.setCurrentIndex(self.theme.display_verticalAlign) @@ -657,7 +651,6 @@ class AmendThemeForm(QtGui.QDialog, Ui_AmendThemeDialog): self.ImageFilenameWidget.setVisible(True) self.GradientLabel.setVisible(False) self.GradientComboBox.setVisible(False) - if not theme.font_main_override: self.FontMainXSpinBox.setEnabled(False) self.FontMainYSpinBox.setEnabled(False) From b90169a1293da9de828bbc3a2d73702311a98aa1 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Fri, 26 Mar 2010 21:04:50 +0000 Subject: [PATCH 22/30] Song editing improvements --- openlp/plugins/songs/forms/editverseform.py | 35 ++++++++++++++++----- 1 file changed, 28 insertions(+), 7 deletions(-) diff --git a/openlp/plugins/songs/forms/editverseform.py b/openlp/plugins/songs/forms/editverseform.py index 7fdea7e8f..f6ace12aa 100644 --- a/openlp/plugins/songs/forms/editverseform.py +++ b/openlp/plugins/songs/forms/editverseform.py @@ -54,25 +54,46 @@ class EditVerseForm(QtGui.QDialog, Ui_EditVerseDialog): QtCore.SIGNAL(u'activated(int)'), self.onVerseComboChanged) def onAddIntro(self): - self.VerseTextEdit.insertPlainText(u'---[Intro:1]---') + self.VerseTextEdit.insertPlainText(u'---[%s:1]---\n' + % self.trUtf8('Intro')) + self.VerseTextEdit.moveCursor(QtGui.QTextCursor.Down) + self.VerseTextEdit.setFocus() def onAddEnding(self): - self.VerseTextEdit.insertPlainText(u'---[Ending:1]---') + self.VerseTextEdit.insertPlainText(u'---[%s:1]---\n' + % self.trUtf8('Ending')) + self.VerseTextEdit.moveCursor(QtGui.QTextCursor.Down) + self.VerseTextEdit.setFocus() def onAddOther(self): - self.VerseTextEdit.insertPlainText(u'---[Other:1]---') + self.VerseTextEdit.insertPlainText(u'---[%s:1]---\n' + % self.trUtf8('Other')) + self.VerseTextEdit.moveCursor(QtGui.QTextCursor.Down) + self.VerseTextEdit.setFocus() def onAddPreChorus(self): - self.VerseTextEdit.insertPlainText(u'---[PreChorus:1]---') + self.VerseTextEdit.insertPlainText(u'---[%s:1]---\n' + % self.trUtf8('Pre-Chorus')) + self.VerseTextEdit.moveCursor(QtGui.QTextCursor.Down) + self.VerseTextEdit.setFocus() def onAddBridge(self): - self.VerseTextEdit.insertPlainText(u'---[Bridge:1]---') + self.VerseTextEdit.insertPlainText(u'---[%s:1]---\n' + % self.trUtf8('Bridge')) + self.VerseTextEdit.moveCursor(QtGui.QTextCursor.Down) + self.VerseTextEdit.setFocus() def onAddChorus(self): - self.VerseTextEdit.insertPlainText(u'---[Chorus:1]---') + self.VerseTextEdit.insertPlainText(u'---[%s:1]---\n' + % self.trUtf8('Chorus')) + self.VerseTextEdit.moveCursor(QtGui.QTextCursor.Down) + self.VerseTextEdit.setFocus() def onAddVerse(self): - self.VerseTextEdit.insertPlainText(u'---[Verse:1]---') + self.VerseTextEdit.insertPlainText(u'---[%s:1]---\n' + % self.trUtf8('Verse')) + self.VerseTextEdit.moveCursor(QtGui.QTextCursor.Down) + self.VerseTextEdit.setFocus() def setVerse(self, text, verseCount=0, single=False, tag=u'Verse:1'): posVerse = 0 From 611ae157909eceeca1ebdfce4f8db01eed281e9e Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sat, 27 Mar 2010 07:01:50 +0000 Subject: [PATCH 23/30] Fix up tag editing --- openlp/plugins/songs/forms/editsongform.py | 5 +++-- openlp/plugins/songs/forms/editverseform.py | 24 ++++++++++++--------- 2 files changed, 17 insertions(+), 12 deletions(-) diff --git a/openlp/plugins/songs/forms/editsongform.py b/openlp/plugins/songs/forms/editsongform.py index 976ee1e78..86c576eed 100644 --- a/openlp/plugins/songs/forms/editsongform.py +++ b/openlp/plugins/songs/forms/editsongform.py @@ -411,9 +411,10 @@ class EditSongForm(QtGui.QDialog, Ui_EditSongDialog): self.SongTabWidget.setCurrentIndex(2) self.AuthorsListView.setFocus() #split the verse list by space and mark lower case for testing + taglist = self.trUtf8(' bcitped') for verse in unicode(self.VerseOrderEdit.text()).lower().split(u' '): if len(verse) > 1: - if verse[0:1] == u'v' and verse[1:].isdigit(): + if verse[0:1] == u'%s' % self.trUtf8('v') and verse[1:].isdigit(): pass else: self.SongTabWidget.setCurrentIndex(0) @@ -421,7 +422,7 @@ class EditSongForm(QtGui.QDialog, Ui_EditSongDialog): return False, \ self.trUtf8('Invalid verse entry - vX') else: - if u' bcitped'.find(verse) > -1: + if taglist.find(verse) > -1: pass else: self.SongTabWidget.setCurrentIndex(0) diff --git a/openlp/plugins/songs/forms/editverseform.py b/openlp/plugins/songs/forms/editverseform.py index f6ace12aa..da9daf089 100644 --- a/openlp/plugins/songs/forms/editverseform.py +++ b/openlp/plugins/songs/forms/editverseform.py @@ -53,53 +53,57 @@ class EditVerseForm(QtGui.QDialog, Ui_EditVerseDialog): QtCore.QObject.connect(self.VerseListComboBox, QtCore.SIGNAL(u'activated(int)'), self.onVerseComboChanged) + def startNewLine(self): + if self.VerseTextEdit.textCursor().columnNumber() != 0: + self.VerseTextEdit.insertPlainText(u'\n') + def onAddIntro(self): + self.startNewLine() self.VerseTextEdit.insertPlainText(u'---[%s:1]---\n' % self.trUtf8('Intro')) - self.VerseTextEdit.moveCursor(QtGui.QTextCursor.Down) self.VerseTextEdit.setFocus() def onAddEnding(self): + self.startNewLine() self.VerseTextEdit.insertPlainText(u'---[%s:1]---\n' % self.trUtf8('Ending')) - self.VerseTextEdit.moveCursor(QtGui.QTextCursor.Down) self.VerseTextEdit.setFocus() def onAddOther(self): + self.startNewLine() self.VerseTextEdit.insertPlainText(u'---[%s:1]---\n' % self.trUtf8('Other')) - self.VerseTextEdit.moveCursor(QtGui.QTextCursor.Down) self.VerseTextEdit.setFocus() def onAddPreChorus(self): + self.startNewLine() self.VerseTextEdit.insertPlainText(u'---[%s:1]---\n' % self.trUtf8('Pre-Chorus')) - self.VerseTextEdit.moveCursor(QtGui.QTextCursor.Down) self.VerseTextEdit.setFocus() def onAddBridge(self): + self.startNewLine() self.VerseTextEdit.insertPlainText(u'---[%s:1]---\n' % self.trUtf8('Bridge')) - self.VerseTextEdit.moveCursor(QtGui.QTextCursor.Down) self.VerseTextEdit.setFocus() def onAddChorus(self): + self.startNewLine() self.VerseTextEdit.insertPlainText(u'---[%s:1]---\n' % self.trUtf8('Chorus')) - self.VerseTextEdit.moveCursor(QtGui.QTextCursor.Down) self.VerseTextEdit.setFocus() def onAddVerse(self): + self.startNewLine() self.VerseTextEdit.insertPlainText(u'---[%s:1]---\n' % self.trUtf8('Verse')) - self.VerseTextEdit.moveCursor(QtGui.QTextCursor.Down) self.VerseTextEdit.setFocus() def setVerse(self, text, verseCount=0, single=False, tag=u'Verse:1'): posVerse = 0 posSub = 0 if len(text) == 0 and not single: - text = u'---[Verse:1]---\n' + text = u'---[%s:1]---\n' % self.trUtf8('Verse') if single: id = tag.split(u':') posVerse = self.VerseListComboBox.findText(id[0], QtCore.Qt.MatchExactly) @@ -145,11 +149,11 @@ class EditVerseForm(QtGui.QDialog, Ui_EditVerseDialog): def getVerseAll(self): text = self.VerseTextEdit.toPlainText() if not text.startsWith(u'---['): - text = u'---[Verse:1]---\n%s' % text + text = u'---[%s:1]---\n%s' % (self.trUtf8('Verse'), text) return text def onVerseComboChanged(self, id): - if unicode(self.VerseListComboBox.currentText()) == u'Verse': + if unicode(self.VerseListComboBox.currentText()) == self.trUtf8('Verse'): self.SubVerseListComboBox.setEnabled(True) else: self.SubVerseListComboBox.setEnabled(False) From 097a414c59997bf5b05ec053978f616ea100aacb Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sat, 27 Mar 2010 07:03:12 +0000 Subject: [PATCH 24/30] oops string bug --- openlp/plugins/songs/forms/editsongform.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/openlp/plugins/songs/forms/editsongform.py b/openlp/plugins/songs/forms/editsongform.py index 86c576eed..a369e46a1 100644 --- a/openlp/plugins/songs/forms/editsongform.py +++ b/openlp/plugins/songs/forms/editsongform.py @@ -411,7 +411,7 @@ class EditSongForm(QtGui.QDialog, Ui_EditSongDialog): self.SongTabWidget.setCurrentIndex(2) self.AuthorsListView.setFocus() #split the verse list by space and mark lower case for testing - taglist = self.trUtf8(' bcitped') + taglist = unicode(self.trUtf8(' bcitped')) for verse in unicode(self.VerseOrderEdit.text()).lower().split(u' '): if len(verse) > 1: if verse[0:1] == u'%s' % self.trUtf8('v') and verse[1:].isdigit(): From d2b56fc7193b66c12b7cb0308c088a1732a2df07 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sat, 27 Mar 2010 07:16:39 +0000 Subject: [PATCH 25/30] Basic verse counting --- openlp/plugins/songs/forms/editverseform.py | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/openlp/plugins/songs/forms/editverseform.py b/openlp/plugins/songs/forms/editverseform.py index da9daf089..2666c146e 100644 --- a/openlp/plugins/songs/forms/editverseform.py +++ b/openlp/plugins/songs/forms/editverseform.py @@ -95,8 +95,10 @@ class EditVerseForm(QtGui.QDialog, Ui_EditVerseDialog): def onAddVerse(self): self.startNewLine() - self.VerseTextEdit.insertPlainText(u'---[%s:1]---\n' - % self.trUtf8('Verse')) + count = self.VerseTextEdit.toPlainText().\ + count(u'---[%s' % self.trUtf8('Verse')) + self.VerseTextEdit.insertPlainText(u'---[%s:%s]---\n' + % (self.trUtf8('Verse'), count + 1)) self.VerseTextEdit.setFocus() def setVerse(self, text, verseCount=0, single=False, tag=u'Verse:1'): From 8df005340938fc132b6f08306e76f88a266a6e0b Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sat, 27 Mar 2010 10:12:11 +0000 Subject: [PATCH 26/30] Fix Copyrights --- openlp/core/ui/serviceitemeditdialog.py | 4 ++-- openlp/core/ui/serviceitemeditform.py | 4 ++-- openlp/plugins/bibles/lib/mediaitem.py | 3 ++- 3 files changed, 6 insertions(+), 5 deletions(-) diff --git a/openlp/core/ui/serviceitemeditdialog.py b/openlp/core/ui/serviceitemeditdialog.py index b388fb98c..fbaa52ca1 100644 --- a/openlp/core/ui/serviceitemeditdialog.py +++ b/openlp/core/ui/serviceitemeditdialog.py @@ -6,8 +6,8 @@ # --------------------------------------------------------------------------- # # Copyright (c) 2008-2010 Raoul Snyman # # Portions copyright (c) 2008-2010 Tim Bentley, Jonathan Corwin, Michael # -# Gorven, Scott Guerrieri, Maikel Stuivenberg, Martin Thompson, Jon Tibble, # -# Carsten Tinggaard # +# Gorven, Scott Guerrieri, Christian Richter, Maikel Stuivenberg, Martin # +# Thompson, Jon Tibble, Carsten Tinggaard # # --------------------------------------------------------------------------- # # 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 # diff --git a/openlp/core/ui/serviceitemeditform.py b/openlp/core/ui/serviceitemeditform.py index 4293e15c8..9df8088c8 100644 --- a/openlp/core/ui/serviceitemeditform.py +++ b/openlp/core/ui/serviceitemeditform.py @@ -6,8 +6,8 @@ # --------------------------------------------------------------------------- # # Copyright (c) 2008-2010 Raoul Snyman # # Portions copyright (c) 2008-2010 Tim Bentley, Jonathan Corwin, Michael # -# Gorven, Scott Guerrieri, Maikel Stuivenberg, Martin Thompson, Jon Tibble, # -# Carsten Tinggaard # +# Gorven, Scott Guerrieri, Christian Richter, Maikel Stuivenberg, Martin # +# Thompson, Jon Tibble, Carsten Tinggaard # # --------------------------------------------------------------------------- # # 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 # diff --git a/openlp/plugins/bibles/lib/mediaitem.py b/openlp/plugins/bibles/lib/mediaitem.py index f550b6e36..56838a41a 100644 --- a/openlp/plugins/bibles/lib/mediaitem.py +++ b/openlp/plugins/bibles/lib/mediaitem.py @@ -509,7 +509,8 @@ class BibleMediaItem(MediaManagerItem): if not service_item.title: service_item.title = u'%s %s' % (book, verse_text) elif service_item.title.find(self.trUtf8(u'etc')) == -1: - service_item.title = u'%s, %s' % (service_item.title, self.trUtf8(u'etc')) + service_item.title = u'%s, %s' \ + % (service_item.title, self.trUtf8(u'etc')) if len(self.parent.settings_tab.bible_theme) == 0: service_item.theme = None else: From 66cd5f042a6b7c494503501516d24c018e9561c8 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sat, 27 Mar 2010 20:27:33 +0000 Subject: [PATCH 27/30] Stop outlines for footers they are too small --- openlp/core/lib/renderer.py | 4 ++-- openlp/core/ui/servicemanager.py | 14 ++++++++++---- 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/openlp/core/lib/renderer.py b/openlp/core/lib/renderer.py index 99b4a7e6f..f574ed6a8 100644 --- a/openlp/core/lib/renderer.py +++ b/openlp/core/lib/renderer.py @@ -543,7 +543,7 @@ class Renderer(object): else: pen = QtGui.QColor(color) x, y = tlcorner - if self._theme.display_outline and outline_size != 0: + if self._theme.display_outline and outline_size != 0 and not footer: path = QtGui.QPainterPath() path.addText(QtCore.QPointF(x, y + metrics.ascent()), font, line) self.painter.setBrush(self.painter.pen().brush()) @@ -554,7 +554,7 @@ class Renderer(object): self.painter.drawText(x, y + metrics.ascent(), line) if self._theme.display_slideTransition: # Print 2nd image with 70% weight - if self._theme.display_outline and outline_size != 0: + if self._theme.display_outline and outline_size != 0 and not footer: path = QtGui.QPainterPath() path.addText(QtCore.QPointF(x, y + metrics.ascent()), font, line) self.painter2.setBrush(self.painter2.pen().brush()) diff --git a/openlp/core/ui/servicemanager.py b/openlp/core/ui/servicemanager.py index 585ed99df..cf9896ce4 100644 --- a/openlp/core/ui/servicemanager.py +++ b/openlp/core/ui/servicemanager.py @@ -659,11 +659,17 @@ class ServiceManager(QtGui.QWidget): self.repaintServiceList(sitem + 1, 0) self.parent.LiveController.replaceServiceManagerItem(item) else: - #nothing selected or dnd + #nothing selected for dnd if self.droppos == 0: - self.serviceItems.append({u'service_item': item, - u'order': len(self.serviceItems) + 1, - u'expanded':expand}) + if isinstance(item, list): + for inditem in item: + self.serviceItems.append({u'service_item': inditem, + u'order': len(self.serviceItems) + 1, + u'expanded':expand}) + else: + self.serviceItems.append({u'service_item': item, + u'order': len(self.serviceItems) + 1, + u'expanded':expand}) self.repaintServiceList(len(self.serviceItems) + 1, 0) else: self.serviceItems.insert(self.droppos, {u'service_item': item, From e67e21f445298fabdbe8c639353af895bdcc86b1 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sun, 28 Mar 2010 15:18:36 +0100 Subject: [PATCH 28/30] Fix loss of slide menu for save services --- openlp/core/lib/serviceitem.py | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/openlp/core/lib/serviceitem.py b/openlp/core/lib/serviceitem.py index edfd17ce1..1d189bfc8 100644 --- a/openlp/core/lib/serviceitem.py +++ b/openlp/core/lib/serviceitem.py @@ -74,6 +74,7 @@ class ServiceItem(object): self._uuid = unicode(uuid.uuid1()) self.autoPreviewAllowed = False self.notes = u'' + self.fromPlugin = False def addIcon(self, icon): """ @@ -208,7 +209,8 @@ class ServiceItem(object): u'notes':self.notes, u'preview':self.autoPreviewAllowed, u'edit':self.edit_enabled, - u'maintain':self.maintain_allowed + u'maintain':self.maintain_allowed, + u'fromPlugin':self.fromPlugin } service_data = [] if self.service_item_type == ServiceItemType.Text: @@ -246,6 +248,7 @@ class ServiceItem(object): self.notes = header[u'notes'] self.edit_enabled = header[u'edit'] self.maintain_allowed = header[u'maintain'] + self.fromPlugin = header[u'fromPlugin'] if self.service_item_type == ServiceItemType.Text: for slide in serviceitem[u'serviceitem'][u'data']: self._raw_frames.append(slide) @@ -282,7 +285,7 @@ class ServiceItem(object): return self._uuid != other._uuid def is_song(self): - return self.name == u'Songs' + return self.name.lower() == u'songs' def is_media(self): return self.name.lower() == u'media' From b8f9f21b5d8acbad081155c26f34951d75fb33f8 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sun, 28 Mar 2010 16:56:49 +0100 Subject: [PATCH 29/30] Review comments --- openlp/core/lib/mediamanageritem.py | 12 ++++++------ openlp/core/lib/serviceitem.py | 14 +++++++------- openlp/core/ui/__init__.py | 4 ++-- openlp/core/ui/maindisplay.py | 10 +++++----- openlp/core/ui/servicemanager.py | 4 ++-- openlp/core/ui/slidecontroller.py | 10 +++++----- openlp/plugins/bibles/lib/mediaitem.py | 4 ++-- openlp/plugins/custom/lib/mediaitem.py | 4 ++-- openlp/plugins/images/lib/mediaitem.py | 4 ++-- openlp/plugins/songs/lib/mediaitem.py | 4 ++-- 10 files changed, 35 insertions(+), 35 deletions(-) diff --git a/openlp/core/lib/mediamanageritem.py b/openlp/core/lib/mediamanageritem.py index 7d410c10f..d0b9824fb 100644 --- a/openlp/core/lib/mediamanageritem.py +++ b/openlp/core/lib/mediamanageritem.py @@ -380,7 +380,7 @@ class MediaManagerItem(QtGui.QWidget): log.debug(self.PluginNameShort + u' Preview requested') service_item = self.buildServiceItem() if service_item: - service_item.fromPlugin = True + service_item.from_plugin = True self.parent.preview_controller.addServiceItem(service_item) def onLiveClick(self): @@ -392,7 +392,7 @@ class MediaManagerItem(QtGui.QWidget): log.debug(self.PluginNameShort + u' Live requested') service_item = self.buildServiceItem() if service_item: - service_item.fromPlugin = True + service_item.from_plugin = True self.parent.live_controller.addServiceItem(service_item) def onAddClick(self): @@ -404,7 +404,7 @@ class MediaManagerItem(QtGui.QWidget): log.debug(self.PluginNameShort + u' Add requested') service_item = self.buildServiceItem() if service_item: - service_item.fromPlugin = False + service_item.from_plugin = False self.parent.service_manager.addServiceItem(service_item) def onAddEditClick(self): @@ -417,8 +417,8 @@ class MediaManagerItem(QtGui.QWidget): service_item = self.parent.service_manager.getServiceItem() if not service_item: QtGui.QMessageBox.information(self, - self.trUtf8('No Servive item selected'), - self.trUtf8('You must select a existing Service Item to add to.')) + self.trUtf8('No Service Item Selected'), + self.trUtf8('You must select a existing service item to add to.')) elif self.title == service_item.name: self.generateSlideData(service_item) self.parent.service_manager.addServiceItem(service_item) @@ -442,4 +442,4 @@ class MediaManagerItem(QtGui.QWidget): if self.generateSlideData(service_item): return service_item else: - return None + return None \ No newline at end of file diff --git a/openlp/core/lib/serviceitem.py b/openlp/core/lib/serviceitem.py index 1d189bfc8..70f56fab9 100644 --- a/openlp/core/lib/serviceitem.py +++ b/openlp/core/lib/serviceitem.py @@ -72,9 +72,9 @@ class ServiceItem(object): self._raw_frames = [] self._display_frames = [] self._uuid = unicode(uuid.uuid1()) - self.autoPreviewAllowed = False + self.auto_preview_allowed = False self.notes = u'' - self.fromPlugin = False + self.from_plugin = False def addIcon(self, icon): """ @@ -207,10 +207,10 @@ class ServiceItem(object): u'type':self.service_item_type, u'audit':self.audit, u'notes':self.notes, - u'preview':self.autoPreviewAllowed, + u'preview':self.auto_preview_allowed, u'edit':self.edit_enabled, u'maintain':self.maintain_allowed, - u'fromPlugin':self.fromPlugin + u'from_plugin':self.from_plugin } service_data = [] if self.service_item_type == ServiceItemType.Text: @@ -244,11 +244,11 @@ class ServiceItem(object): self.addIcon(header[u'icon']) self.raw_footer = header[u'footer'] self.audit = header[u'audit'] - self.autoPreviewAllowed = header[u'preview'] + self.auto_preview_allowed = header[u'preview'] self.notes = header[u'notes'] self.edit_enabled = header[u'edit'] self.maintain_allowed = header[u'maintain'] - self.fromPlugin = header[u'fromPlugin'] + self.from_plugin = header[u'from_plugin'] if self.service_item_type == ServiceItemType.Text: for slide in serviceitem[u'serviceitem'][u'data']: self._raw_frames.append(slide) @@ -327,4 +327,4 @@ class ServiceItem(object): def request_audit(self): if self.audit: - Receiver.send_message(u'songusage_live', self.audit) + Receiver.send_message(u'songusage_live', self.audit) \ No newline at end of file diff --git a/openlp/core/ui/__init__.py b/openlp/core/ui/__init__.py index b46ea769b..3865ec80f 100644 --- a/openlp/core/ui/__init__.py +++ b/openlp/core/ui/__init__.py @@ -23,7 +23,7 @@ # Temple Place, Suite 330, Boston, MA 02111-1307 USA # ############################################################################### -from slidecontroller import DisplayHideMode +from slidecontroller import HideMode from servicenoteform import ServiceNoteForm from serviceitemeditform import ServiceItemEditForm from screen import ScreenList @@ -43,4 +43,4 @@ from mainwindow import MainWindow __all__ = ['SplashScreen', 'AboutForm', 'SettingsForm', 'MainWindow', 'MainDisplay', 'SlideController', 'ServiceManager', 'ThemeManager', - 'AmendThemeForm', 'MediaDockManager', 'ServiceItemNoteForm'] + 'AmendThemeForm', 'MediaDockManager', 'ServiceItemNoteForm'] \ No newline at end of file diff --git a/openlp/core/ui/maindisplay.py b/openlp/core/ui/maindisplay.py index 03cd9d830..eaf1ed78f 100644 --- a/openlp/core/ui/maindisplay.py +++ b/openlp/core/ui/maindisplay.py @@ -30,7 +30,7 @@ from PyQt4 import QtCore, QtGui from PyQt4.phonon import Phonon from openlp.core.lib import Receiver, resize_image -from openlp.core.ui import DisplayHideMode +from openlp.core.ui import HideMode log = logging.getLogger(__name__) @@ -254,13 +254,13 @@ class MainDisplay(DisplayWidget): self.waitingFrame = frame self.waitingFrameTrans = transition - def blankDisplay(self, blankType=DisplayHideMode.Blank, blanked=True): + def blankDisplay(self, blankType=HideMode.Blank, blanked=True): log.debug(u'Blank main Display %d' % blanked) if blanked: self.displayBlank = True - if blankType == DisplayHideMode.Blank: + if blankType == HideMode.Blank: self.display_text.setPixmap(QtGui.QPixmap.fromImage(self.blankFrame)) - elif blankType == DisplayHideMode.Theme: + elif blankType == HideMode.Theme: theme = self.parent.RenderManager.renderer.bg_frame if not theme: theme = self.blankFrame @@ -320,4 +320,4 @@ class MainDisplay(DisplayWidget): self.video.setVisible(False) self.display_text.show() self.display_image.show() - self.blankDisplay(False, False) + self.blankDisplay(False, False) \ No newline at end of file diff --git a/openlp/core/ui/servicemanager.py b/openlp/core/ui/servicemanager.py index cf9896ce4..4565a9527 100644 --- a/openlp/core/ui/servicemanager.py +++ b/openlp/core/ui/servicemanager.py @@ -34,7 +34,7 @@ from PyQt4 import QtCore, QtGui from openlp.core.lib import PluginConfig, OpenLPToolbar, ServiceItem, \ contextMenuAction, Receiver, str_to_bool, build_icon -from openlp.core.ui import ServiceNoteForm, ServiceItemEditForm +from openlp.core.ui import ServiceNoteForm, ServiceItemEditForm class ServiceManagerList(QtGui.QTreeWidget): @@ -713,7 +713,7 @@ class ServiceManager(QtGui.QWidget): get_config(u'auto preview', u'False')): item += 1 if self.serviceItems and item < len(self.serviceItems) and \ - self.serviceItems[item][u'service_item'].autoPreviewAllowed: + self.serviceItems[item][u'service_item'].auto_preview_allowed: self.parent.PreviewController.addServiceManagerItem( self.serviceItems[item][u'service_item'], 0) diff --git a/openlp/core/ui/slidecontroller.py b/openlp/core/ui/slidecontroller.py index 92f383c57..d11c4007e 100644 --- a/openlp/core/ui/slidecontroller.py +++ b/openlp/core/ui/slidecontroller.py @@ -30,7 +30,7 @@ import os from PyQt4 import QtCore, QtGui from PyQt4.phonon import Phonon -class DisplayHideMode(object): +class HideMode(object): """ This is basically an enumeration class which specifies the mode of a Bible. Mode refers to whether or not a Bible in OpenLP is a full Bible or needs to @@ -395,7 +395,7 @@ class SlideController(QtGui.QWidget): self.Toolbar.setVisible(True) self.Mediabar.setVisible(False) self.Toolbar.makeWidgetsInvisible(self.song_edit_list) - if item.edit_enabled and item.fromPlugin: + if item.edit_enabled and item.from_plugin: self.Toolbar.makeWidgetsVisible(self.song_edit_list) elif item.is_media(): self.Toolbar.setVisible(False) @@ -560,7 +560,7 @@ class SlideController(QtGui.QWidget): log.debug(u'onBlankDisplay %d' % force) if force: self.blankButton.setChecked(True) - self.blankScreen(DisplayHideMode.Blank, self.blankButton.isChecked()) + self.blankScreen(HideMode.Blank, self.blankButton.isChecked()) self.parent.generalConfig.set_config(u'screen blank', self.blankButton.isChecked()) @@ -571,7 +571,7 @@ class SlideController(QtGui.QWidget): log.debug(u'onThemeDisplay %d' % force) if force: self.themeButton.setChecked(True) - self.blankScreen(DisplayHideMode.Theme, self.themeButton.isChecked()) + self.blankScreen(HideMode.Theme, self.themeButton.isChecked()) def onHideDisplay(self, force=False): """ @@ -585,7 +585,7 @@ class SlideController(QtGui.QWidget): else: self.parent.mainDisplay.showDisplay() - def blankScreen(self, blankType, blanked=False): + def blankScreen(self, blankType, blanked=False): """ Blank the display screen. """ diff --git a/openlp/plugins/bibles/lib/mediaitem.py b/openlp/plugins/bibles/lib/mediaitem.py index c14996512..1abce732f 100644 --- a/openlp/plugins/bibles/lib/mediaitem.py +++ b/openlp/plugins/bibles/lib/mediaitem.py @@ -449,7 +449,7 @@ class BibleMediaItem(MediaManagerItem): raw_slides = [] raw_footer = [] bible_text = u'' - service_item.autoPreviewAllowed = True + service_item.auto_preview_allowed = True #If we want to use a 2nd translation / version bible2 = u'' if self.SearchTabWidget.currentIndex() == 0: @@ -608,4 +608,4 @@ class BibleMediaItem(MediaManagerItem): def searchByReference(self, bible, search): log.debug(u'searchByReference %s, %s', bible, search) - self.search_results = self.parent.manager.get_verses(bible, search) + self.search_results = self.parent.manager.get_verses(bible, search) \ No newline at end of file diff --git a/openlp/plugins/custom/lib/mediaitem.py b/openlp/plugins/custom/lib/mediaitem.py index 4679be69f..744978967 100644 --- a/openlp/plugins/custom/lib/mediaitem.py +++ b/openlp/plugins/custom/lib/mediaitem.py @@ -144,7 +144,7 @@ class CustomMediaItem(MediaManagerItem): item_id = (item.data(QtCore.Qt.UserRole)).toInt()[0] else: item_id = self.remoteCustom - service_item.autoPreviewAllowed = True + service_item.auto_preview_allowed = True customSlide = self.parent.custommanager.get_custom(item_id) title = customSlide.title credit = customSlide.credits @@ -166,4 +166,4 @@ class CustomMediaItem(MediaManagerItem): else: raw_footer.append(u'') service_item.raw_footer = raw_footer - return True + return True \ No newline at end of file diff --git a/openlp/plugins/images/lib/mediaitem.py b/openlp/plugins/images/lib/mediaitem.py index 73c61df40..ff36d347d 100644 --- a/openlp/plugins/images/lib/mediaitem.py +++ b/openlp/plugins/images/lib/mediaitem.py @@ -140,7 +140,7 @@ class ImageMediaItem(MediaManagerItem): items = self.ListView.selectedIndexes() if items: service_item.title = self.trUtf8('Image(s)') - service_item.autoPreviewAllowed = True + service_item.auto_preview_allowed = True service_item.maintain_allowed = True for item in items: bitem = self.ListView.item(item.row()) @@ -165,4 +165,4 @@ class ImageMediaItem(MediaManagerItem): self.parent.maindisplay.addImageWithText(frame) def onPreviewClick(self): - MediaManagerItem.onPreviewClick(self) + MediaManagerItem.onPreviewClick(self) \ No newline at end of file diff --git a/openlp/plugins/songs/lib/mediaitem.py b/openlp/plugins/songs/lib/mediaitem.py index c7b29afd9..9ac8ec977 100644 --- a/openlp/plugins/songs/lib/mediaitem.py +++ b/openlp/plugins/songs/lib/mediaitem.py @@ -290,7 +290,7 @@ class SongMediaItem(MediaManagerItem): item_id = (item.data(QtCore.Qt.UserRole)).toInt()[0] else: item_id = self.remoteSong - service_item.autoPreviewAllowed = True + service_item.auto_preview_allowed = True song = self.parent.songmanager.get_song(item_id) service_item.theme = song.theme_name service_item.edit_enabled = True @@ -345,4 +345,4 @@ class SongMediaItem(MediaManagerItem): service_item.audit = [ song.title, author_audit, song.copyright, song.ccli_number ] - return True + return True \ No newline at end of file From afc1fbde17f70708ce25711eaadf9e562143c7b5 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sun, 28 Mar 2010 17:11:33 +0100 Subject: [PATCH 30/30] Remove ...s --- openlp/core/lib/mediamanageritem.py | 4 ++-- openlp/plugins/images/lib/mediaitem.py | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/openlp/core/lib/mediamanageritem.py b/openlp/core/lib/mediamanageritem.py index d0b9824fb..5dc14e50e 100644 --- a/openlp/core/lib/mediamanageritem.py +++ b/openlp/core/lib/mediamanageritem.py @@ -410,7 +410,7 @@ class MediaManagerItem(QtGui.QWidget): def onAddEditClick(self): if not self.ListView.selectedIndexes() and not self.remoteTriggered: QtGui.QMessageBox.information(self, - self.trUtf8('No items selected...'), + self.trUtf8('No items selected'), self.trUtf8('You must select one or more items')) else: log.debug(self.PluginNameShort + u' Add requested') @@ -442,4 +442,4 @@ class MediaManagerItem(QtGui.QWidget): if self.generateSlideData(service_item): return service_item else: - return None \ No newline at end of file + return None diff --git a/openlp/plugins/images/lib/mediaitem.py b/openlp/plugins/images/lib/mediaitem.py index ff36d347d..f3d09f5e3 100644 --- a/openlp/plugins/images/lib/mediaitem.py +++ b/openlp/plugins/images/lib/mediaitem.py @@ -155,7 +155,7 @@ class ImageMediaItem(MediaManagerItem): def onReplaceClick(self): if not self.ListView.selectedIndexes(): QtGui.QMessageBox.information(self, - self.trUtf8('No item selected...'), + self.trUtf8('No item selected'), self.trUtf8('You must select one item')) items = self.ListView.selectedIndexes() for item in items: @@ -165,4 +165,4 @@ class ImageMediaItem(MediaManagerItem): self.parent.maindisplay.addImageWithText(frame) def onPreviewClick(self): - MediaManagerItem.onPreviewClick(self) \ No newline at end of file + MediaManagerItem.onPreviewClick(self)