From 624216a1b86b7fb5864d738805f79c344c9c1a58 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sat, 3 Dec 2011 09:05:01 +0000 Subject: [PATCH 01/13] add field and usage --- openlp/core/lib/db.py | 4 ++++ openlp/plugins/songs/lib/db.py | 3 ++- openlp/plugins/songs/lib/mediaitem.py | 9 ++++++++- openlp/plugins/songs/lib/upgrade.py | 13 ++++++++++++- openlp/plugins/songs/lib/xml.py | 4 ++-- openlp/plugins/songs/songsplugin.py | 3 +++ 6 files changed, 31 insertions(+), 5 deletions(-) diff --git a/openlp/core/lib/db.py b/openlp/core/lib/db.py index cafc867b3..8c39750b5 100644 --- a/openlp/core/lib/db.py +++ b/openlp/core/lib/db.py @@ -361,6 +361,10 @@ class Manager(object): ``object_class`` The type of object to delete + + ``filter_clause`` + The filter governing selection of objects to return. Defaults to + None. """ try: query = self.session.query(object_class) diff --git a/openlp/plugins/songs/lib/db.py b/openlp/plugins/songs/lib/db.py index 37ee42451..22f04ec08 100644 --- a/openlp/plugins/songs/lib/db.py +++ b/openlp/plugins/songs/lib/db.py @@ -199,7 +199,8 @@ def init_schema(url): Column(u'search_lyrics', types.UnicodeText, nullable=False), Column(u'create_date', types.DateTime(), default=func.now()), Column(u'last_modified', types.DateTime(), default=func.now(), - onupdate=func.now()) + onupdate=func.now()), + Column(u'temporary', types.Unicode(1), default=u'N') ) # Definition of the "topics" table diff --git a/openlp/plugins/songs/lib/mediaitem.py b/openlp/plugins/songs/lib/mediaitem.py index dad95c61b..0af1a56a7 100644 --- a/openlp/plugins/songs/lib/mediaitem.py +++ b/openlp/plugins/songs/lib/mediaitem.py @@ -270,6 +270,9 @@ class SongMediaItem(MediaManagerItem): searchresults.sort( cmp=locale.strcoll, key=lambda song: song.title.lower()) for song in searchresults: + # Do not display temporary songs + if song.temporary == u'Y': + break author_list = [author.display_name for author in song.authors] song_title = unicode(song.title) song_detail = u'%s (%s)' % (song_title, u', '.join(author_list)) @@ -286,6 +289,9 @@ class SongMediaItem(MediaManagerItem): self.listView.clear() for author in searchresults: for song in author.songs: + # Do not display temporary songs + if song.temporary == u'Y': + break song_detail = u'%s (%s)' % (author.display_name, song.title) song_name = QtGui.QListWidgetItem(song_detail) song_name.setData(QtCore.Qt.UserRole, QtCore.QVariant(song.id)) @@ -561,7 +567,8 @@ class SongMediaItem(MediaManagerItem): self.onSearchTextButtonClick() else: # Make sure we temporary import formatting tags. - self.openLyrics.xml_to_song(item.xml_version, True) + song = self.openLyrics.xml_to_song(item.xml_version, True) + #editId = song.id # Update service with correct song id. if editId: Receiver.send_message(u'service_item_update', diff --git a/openlp/plugins/songs/lib/upgrade.py b/openlp/plugins/songs/lib/upgrade.py index 7752c7e33..6d56467e8 100644 --- a/openlp/plugins/songs/lib/upgrade.py +++ b/openlp/plugins/songs/lib/upgrade.py @@ -34,7 +34,9 @@ from sqlalchemy.sql.expression import func from migrate import changeset from migrate.changeset.constraint import ForeignKeyConstraint -__version__ = 2 +from openlp.plugins.songs.lib.db import Song + +__version__ = 3 def upgrade_setup(metadata): """ @@ -86,4 +88,13 @@ def upgrade_2(session, metadata, tables): .create(table=tables[u'songs']) Column(u'last_modified', types.DateTime(), default=func.now())\ .create(table=tables[u'songs']) + +def upgrade_3(session, metadata, tables): + """ + Version 3 upgrade. + + This upgrade adds a temporary song flag to the songs table + """ + Column(u'temporary', types.Unicode(1), default=u'N')\ + .create(table=tables[u'songs']) diff --git a/openlp/plugins/songs/lib/xml.py b/openlp/plugins/songs/lib/xml.py index aaf82b395..ee4ed74bd 100644 --- a/openlp/plugins/songs/lib/xml.py +++ b/openlp/plugins/songs/lib/xml.py @@ -372,13 +372,13 @@ class OpenLyrics(object): # Formatting tags are new in OpenLyrics 0.8 if float(song_xml.get(u'version')) > 0.7: self._process_formatting_tags(song_xml, parse_and_not_save) - if parse_and_not_save: - return song = Song() # Values will be set when cleaning the song. song.search_lyrics = u'' song.verse_order = u'' song.search_title = u'' + if parse_and_not_save: + song.temporary = u'Y' self._process_copyright(properties, song) self._process_cclinumber(properties, song) self._process_titles(properties, song) diff --git a/openlp/plugins/songs/songsplugin.py b/openlp/plugins/songs/songsplugin.py index 54b1d3f1f..57ddb4bae 100644 --- a/openlp/plugins/songs/songsplugin.py +++ b/openlp/plugins/songs/songsplugin.py @@ -261,6 +261,9 @@ class SongsPlugin(Plugin): Time to tidy up on exit """ log.info(u'Songs Finalising') + # Remove temporary songs + self.manager.delete_all_objects(Song, Song.temporary == u'Y') + # Clean up files and connections self.manager.finalise() self.songImportItem.setVisible(False) self.songExportItem.setVisible(False) From 8c4397d380356e88d253913e914900b8d1ab004f Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sat, 3 Dec 2011 17:01:57 +0000 Subject: [PATCH 02/13] Head --- openlp/core/lib/db.py | 6 ++++-- openlp/plugins/songs/lib/mediaitem.py | 6 +++--- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/openlp/core/lib/db.py b/openlp/core/lib/db.py index 8c39750b5..9a328c552 100644 --- a/openlp/core/lib/db.py +++ b/openlp/core/lib/db.py @@ -201,7 +201,9 @@ class Manager(object): settings.endGroup() if upgrade_mod: db_ver, up_ver = upgrade_db(self.db_url, upgrade_mod) + print db_ver, up_ver, db_ver > up_ver if db_ver > up_ver: + print "hello" critical_error_message_box( translate('OpenLP.Manager', 'Database Error'), unicode(translate('OpenLP.Manager', 'The database being ' @@ -361,10 +363,10 @@ class Manager(object): ``object_class`` The type of object to delete - + ``filter_clause`` The filter governing selection of objects to return. Defaults to - None. + None. """ try: query = self.session.query(object_class) diff --git a/openlp/plugins/songs/lib/mediaitem.py b/openlp/plugins/songs/lib/mediaitem.py index 0af1a56a7..6ded39f83 100644 --- a/openlp/plugins/songs/lib/mediaitem.py +++ b/openlp/plugins/songs/lib/mediaitem.py @@ -272,7 +272,7 @@ class SongMediaItem(MediaManagerItem): for song in searchresults: # Do not display temporary songs if song.temporary == u'Y': - break + continue author_list = [author.display_name for author in song.authors] song_title = unicode(song.title) song_detail = u'%s (%s)' % (song_title, u', '.join(author_list)) @@ -291,7 +291,7 @@ class SongMediaItem(MediaManagerItem): for song in author.songs: # Do not display temporary songs if song.temporary == u'Y': - break + continue song_detail = u'%s (%s)' % (author.display_name, song.title) song_name = QtGui.QListWidgetItem(song_detail) song_name.setData(QtCore.Qt.UserRole, QtCore.QVariant(song.id)) @@ -568,7 +568,7 @@ class SongMediaItem(MediaManagerItem): else: # Make sure we temporary import formatting tags. song = self.openLyrics.xml_to_song(item.xml_version, True) - #editId = song.id + editId = song.id # Update service with correct song id. if editId: Receiver.send_message(u'service_item_update', From 6698ce578d0f7dde066aaec8c7a36d1393418ca8 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sat, 3 Dec 2011 19:08:02 +0000 Subject: [PATCH 03/13] Change Data type --- openlp/core/lib/db.py | 1 - openlp/plugins/songs/lib/db.py | 2 +- openlp/plugins/songs/lib/mediaitem.py | 4 ++-- openlp/plugins/songs/lib/upgrade.py | 4 ++-- openlp/plugins/songs/lib/xml.py | 2 +- openlp/plugins/songs/songsplugin.py | 2 +- 6 files changed, 7 insertions(+), 8 deletions(-) diff --git a/openlp/core/lib/db.py b/openlp/core/lib/db.py index c23cb065e..4a9cb0968 100644 --- a/openlp/core/lib/db.py +++ b/openlp/core/lib/db.py @@ -202,7 +202,6 @@ class Manager(object): settings.endGroup() if upgrade_mod: db_ver, up_ver = upgrade_db(self.db_url, upgrade_mod) - print db_ver, up_ver, db_ver > up_ver if db_ver > up_ver: print "hello" critical_error_message_box( diff --git a/openlp/plugins/songs/lib/db.py b/openlp/plugins/songs/lib/db.py index 22f04ec08..ce228e5f8 100644 --- a/openlp/plugins/songs/lib/db.py +++ b/openlp/plugins/songs/lib/db.py @@ -200,7 +200,7 @@ def init_schema(url): Column(u'create_date', types.DateTime(), default=func.now()), Column(u'last_modified', types.DateTime(), default=func.now(), onupdate=func.now()), - Column(u'temporary', types.Unicode(1), default=u'N') + Column(u'temporary', types.Boolean(), default=False) ) # Definition of the "topics" table diff --git a/openlp/plugins/songs/lib/mediaitem.py b/openlp/plugins/songs/lib/mediaitem.py index 6ded39f83..c73966dd2 100644 --- a/openlp/plugins/songs/lib/mediaitem.py +++ b/openlp/plugins/songs/lib/mediaitem.py @@ -271,7 +271,7 @@ class SongMediaItem(MediaManagerItem): cmp=locale.strcoll, key=lambda song: song.title.lower()) for song in searchresults: # Do not display temporary songs - if song.temporary == u'Y': + if song.temporary: continue author_list = [author.display_name for author in song.authors] song_title = unicode(song.title) @@ -290,7 +290,7 @@ class SongMediaItem(MediaManagerItem): for author in searchresults: for song in author.songs: # Do not display temporary songs - if song.temporary == u'Y': + if song.temporary: continue song_detail = u'%s (%s)' % (author.display_name, song.title) song_name = QtGui.QListWidgetItem(song_detail) diff --git a/openlp/plugins/songs/lib/upgrade.py b/openlp/plugins/songs/lib/upgrade.py index 819a13d2d..25f90e860 100644 --- a/openlp/plugins/songs/lib/upgrade.py +++ b/openlp/plugins/songs/lib/upgrade.py @@ -87,13 +87,13 @@ def upgrade_2(session, metadata, tables): .create(table=tables[u'songs']) Column(u'last_modified', types.DateTime(), default=func.now())\ .create(table=tables[u'songs']) - + def upgrade_3(session, metadata, tables): """ Version 3 upgrade. This upgrade adds a temporary song flag to the songs table """ - Column(u'temporary', types.Unicode(1), default=u'N')\ + Column(u'temporary', types.Boolean(), default=False)\ .create(table=tables[u'songs']) diff --git a/openlp/plugins/songs/lib/xml.py b/openlp/plugins/songs/lib/xml.py index ee4ed74bd..99427d979 100644 --- a/openlp/plugins/songs/lib/xml.py +++ b/openlp/plugins/songs/lib/xml.py @@ -378,7 +378,7 @@ class OpenLyrics(object): song.verse_order = u'' song.search_title = u'' if parse_and_not_save: - song.temporary = u'Y' + song.temporary = True self._process_copyright(properties, song) self._process_cclinumber(properties, song) self._process_titles(properties, song) diff --git a/openlp/plugins/songs/songsplugin.py b/openlp/plugins/songs/songsplugin.py index 19f688186..39e1360fa 100644 --- a/openlp/plugins/songs/songsplugin.py +++ b/openlp/plugins/songs/songsplugin.py @@ -265,7 +265,7 @@ class SongsPlugin(Plugin): """ log.info(u'Songs Finalising') # Remove temporary songs - self.manager.delete_all_objects(Song, Song.temporary == u'Y') + self.manager.delete_all_objects(Song, Song.temporary == True) # Clean up files and connections self.manager.finalise() self.songImportItem.setVisible(False) From 456d7ec68ea2d05ac4445908727e29b9c0d87d11 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sun, 4 Dec 2011 07:27:49 +0000 Subject: [PATCH 04/13] remove print --- openlp/core/lib/db.py | 1 - 1 file changed, 1 deletion(-) diff --git a/openlp/core/lib/db.py b/openlp/core/lib/db.py index 4a9cb0968..160a404a5 100644 --- a/openlp/core/lib/db.py +++ b/openlp/core/lib/db.py @@ -203,7 +203,6 @@ class Manager(object): if upgrade_mod: db_ver, up_ver = upgrade_db(self.db_url, upgrade_mod) if db_ver > up_ver: - print "hello" critical_error_message_box( translate('OpenLP.Manager', 'Database Error'), unicode(translate('OpenLP.Manager', 'The database being ' From f751ae092a566cd783466c334c4fd8bb68eaa406 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sun, 4 Dec 2011 16:19:45 +0000 Subject: [PATCH 05/13] fix exit code --- openlp/plugins/songs/songsplugin.py | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/openlp/plugins/songs/songsplugin.py b/openlp/plugins/songs/songsplugin.py index 39e1360fa..4f0e9d77a 100644 --- a/openlp/plugins/songs/songsplugin.py +++ b/openlp/plugins/songs/songsplugin.py @@ -265,7 +265,9 @@ class SongsPlugin(Plugin): """ log.info(u'Songs Finalising') # Remove temporary songs - self.manager.delete_all_objects(Song, Song.temporary == True) + songs = self.manager.get_all_objects(Song, Song.temporary == True) + for song in songs: + self.manager.delete_object(Song, song.id) # Clean up files and connections self.manager.finalise() self.songImportItem.setVisible(False) From 17bca693c6b3f3af40937ec526aaa4872c0f0da6 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sun, 4 Dec 2011 16:36:18 +0000 Subject: [PATCH 06/13] Block song exports --- openlp/core/lib/db.py | 5 ++++- openlp/plugins/songs/forms/songexportform.py | 3 +++ 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/openlp/core/lib/db.py b/openlp/core/lib/db.py index 160a404a5..b6f12d180 100644 --- a/openlp/core/lib/db.py +++ b/openlp/core/lib/db.py @@ -358,7 +358,10 @@ class Manager(object): def delete_all_objects(self, object_class, filter_clause=None): """ - Delete all object records + Delete all object records. + This method should only be used for simple tables and not ones with + relationships. The relationships are not deleted from the database and + this will lead to database corruptions. ``object_class`` The type of object to delete diff --git a/openlp/plugins/songs/forms/songexportform.py b/openlp/plugins/songs/forms/songexportform.py index 22020a401..20a52c82d 100644 --- a/openlp/plugins/songs/forms/songexportform.py +++ b/openlp/plugins/songs/forms/songexportform.py @@ -252,6 +252,9 @@ class SongExportForm(OpenLPWizard): songs = self.plugin.manager.get_all_objects(Song) songs.sort(cmp=locale.strcoll, key=lambda song: song.title.lower()) for song in songs: + # No need to export temporary songs. + if song.temporary: + continue authors = u', '.join([author.display_name for author in song.authors]) title = u'%s (%s)' % (unicode(song.title), authors) From d05c6b8d70e0c2c7851a4200a45769d682c9385f Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Mon, 5 Dec 2011 19:47:50 +0000 Subject: [PATCH 07/13] Fix up song import code --- openlp/plugins/songs/lib/mediaitem.py | 7 +++++-- openlp/plugins/songs/lib/xml.py | 13 ++++++------- 2 files changed, 11 insertions(+), 9 deletions(-) diff --git a/openlp/plugins/songs/lib/mediaitem.py b/openlp/plugins/songs/lib/mediaitem.py index c73966dd2..c5b59b0fe 100644 --- a/openlp/plugins/songs/lib/mediaitem.py +++ b/openlp/plugins/songs/lib/mediaitem.py @@ -558,16 +558,19 @@ class SongMediaItem(MediaManagerItem): # If there's any backing tracks, copy them over. if len(item.background_audio) > 0: self._updateBackgroundAudio(song, item) - if add_song and self.addSongFromService: + if add_song: song = self.openLyrics.xml_to_song(item.xml_version) # If there's any backing tracks, copy them over. if len(item.background_audio) > 0: self._updateBackgroundAudio(song, item) editId = song.id self.onSearchTextButtonClick() - else: + elif not self.addSongFromService: # Make sure we temporary import formatting tags. song = self.openLyrics.xml_to_song(item.xml_version, True) + # If there's any backing tracks, copy them over. + if len(item.background_audio) > 0: + self._updateBackgroundAudio(song, item) editId = song.id # Update service with correct song id. if editId: diff --git a/openlp/plugins/songs/lib/xml.py b/openlp/plugins/songs/lib/xml.py index 99427d979..b16db7e94 100644 --- a/openlp/plugins/songs/lib/xml.py +++ b/openlp/plugins/songs/lib/xml.py @@ -346,7 +346,7 @@ class OpenLyrics(object): lines_element.set(u'break', u'optional') return self._extract_xml(song_xml) - def xml_to_song(self, xml, parse_and_not_save=False): + def xml_to_song(self, xml, parse_and_temporary_save=False): """ Create and save a song from OpenLyrics format xml to the database. Since we also export XML from external sources (e. g. OpenLyrics import), we @@ -355,9 +355,9 @@ class OpenLyrics(object): ``xml`` The XML to parse (unicode). - ``parse_and_not_save`` - Switch to skip processing the whole song and to prevent storing the - songs to the database. Defaults to ``False``. + ``parse_and_temporary_save`` + Switch to skip processing the whole song and storing the songs in + the database with a temporary flag. Defaults to ``False``. """ # No xml get out of here. if not xml: @@ -371,14 +371,13 @@ class OpenLyrics(object): return None # Formatting tags are new in OpenLyrics 0.8 if float(song_xml.get(u'version')) > 0.7: - self._process_formatting_tags(song_xml, parse_and_not_save) + self._process_formatting_tags(song_xml, parse_and_temporary_save) song = Song() # Values will be set when cleaning the song. song.search_lyrics = u'' song.verse_order = u'' song.search_title = u'' - if parse_and_not_save: - song.temporary = True + song.temporary = parse_and_temporary_save self._process_copyright(properties, song) self._process_cclinumber(properties, song) self._process_titles(properties, song) From ecba19f124933f175198b97942ef6bb238da6e72 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Thu, 8 Dec 2011 19:42:31 +0000 Subject: [PATCH 08/13] Fixes --- openlp/plugins/songs/lib/mediaitem.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/openlp/plugins/songs/lib/mediaitem.py b/openlp/plugins/songs/lib/mediaitem.py index c5b59b0fe..be6dfa6be 100644 --- a/openlp/plugins/songs/lib/mediaitem.py +++ b/openlp/plugins/songs/lib/mediaitem.py @@ -558,7 +558,7 @@ class SongMediaItem(MediaManagerItem): # If there's any backing tracks, copy them over. if len(item.background_audio) > 0: self._updateBackgroundAudio(song, item) - if add_song: + if add_song and self.addSongFromService: song = self.openLyrics.xml_to_song(item.xml_version) # If there's any backing tracks, copy them over. if len(item.background_audio) > 0: From 1d673caff49ec9894bd650cb637122a2cf542a22 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sat, 10 Dec 2011 08:45:17 +0000 Subject: [PATCH 09/13] Fixes and notifications --- openlp/core/lib/serviceitem.py | 1 + openlp/core/ui/servicemanager.py | 22 ++++++++++++++++++++-- openlp/plugins/songs/lib/mediaitem.py | 6 ++++-- 3 files changed, 25 insertions(+), 4 deletions(-) diff --git a/openlp/core/lib/serviceitem.py b/openlp/core/lib/serviceitem.py index b12a27f1d..62064dc06 100644 --- a/openlp/core/lib/serviceitem.py +++ b/openlp/core/lib/serviceitem.py @@ -119,6 +119,7 @@ class ServiceItem(object): self.image_border = u'#000000' self.background_audio = [] self.theme_overwritten = False + self.temporary_edit = False self._new_item() def _new_item(self): diff --git a/openlp/core/ui/servicemanager.py b/openlp/core/ui/servicemanager.py index 8ad2db9c2..fa1ccede0 100644 --- a/openlp/core/ui/servicemanager.py +++ b/openlp/core/ui/servicemanager.py @@ -37,7 +37,7 @@ log = logging.getLogger(__name__) from PyQt4 import QtCore, QtGui from openlp.core.lib import OpenLPToolbar, ServiceItem, Receiver, build_icon, \ - ItemCapabilities, SettingsManager, translate + ItemCapabilities, SettingsManager, translate, str_to_bool from openlp.core.lib.theme import ThemeLevel from openlp.core.lib.ui import UiStrings, critical_error_message_box, \ context_menu_action, context_menu_separator, find_and_set_in_combo_box @@ -670,6 +670,7 @@ class ServiceManager(QtGui.QWidget): # if the item has been processed if serviceItem._uuid == self.loadItem_uuid: serviceItem.edit_id = int(self.loadItem_editId) + serviceItem.temporary_edit = self.loadItem_temporary self.addServiceItem(serviceItem, repaint=False) delete_file(p_file) self.setFileName(fileName) @@ -999,6 +1000,17 @@ class ServiceManager(QtGui.QWidget): painter.drawImage(0, 0, overlay) painter.end() treewidgetitem.setIcon(0, build_icon(icon)) + elif serviceitem.temporary_edit: + icon = QtGui.QImage(serviceitem.icon) + icon = icon.scaled(80, 80, QtCore.Qt.KeepAspectRatio, + QtCore.Qt.SmoothTransformation) + overlay = QtGui.QImage(':/general/general_export.png') + overlay = overlay.scaled(40, 40, QtCore.Qt.KeepAspectRatio, + QtCore.Qt.SmoothTransformation) + painter = QtGui.QPainter(icon) + painter.drawImage(40, 0, overlay) + painter.end() + treewidgetitem.setIcon(0, build_icon(icon)) else: treewidgetitem.setIcon(0, serviceitem.iconic_representation) else: @@ -1006,6 +1018,11 @@ class ServiceManager(QtGui.QWidget): build_icon(u':/general/general_delete.png')) treewidgetitem.setText(0, serviceitem.get_display_title()) tips = [] + if serviceitem.temporary_edit: + tips.append(u'%s: %s' % + (unicode(translate('OpenLP.ServiceManager', 'Edit')), + (unicode(translate('OpenLP.ServiceManager', + 'Service copy only'))))) if serviceitem.theme and serviceitem.theme != -1: tips.append(u'%s: %s' % (unicode(translate('OpenLP.ServiceManager', 'Slide theme')), @@ -1127,8 +1144,9 @@ class ServiceManager(QtGui.QWidget): Triggered from plugins to update service items. Save the values as they will be used as part of the service load """ - editId, self.loadItem_uuid = message.split(u':') + editId, self.loadItem_uuid, temporary = message.split(u':') self.loadItem_editId = int(editId) + self.loadItem_temporary = str_to_bool(temporary) def replaceServiceItem(self, newItem): """ diff --git a/openlp/plugins/songs/lib/mediaitem.py b/openlp/plugins/songs/lib/mediaitem.py index be6dfa6be..052fb5b7b 100644 --- a/openlp/plugins/songs/lib/mediaitem.py +++ b/openlp/plugins/songs/lib/mediaitem.py @@ -540,6 +540,7 @@ class SongMediaItem(MediaManagerItem): Song.search_title.asc()) editId = 0 add_song = True + temporary = False if search_results: for song in search_results: author_list = item.data_string[u'authors'] @@ -565,17 +566,18 @@ class SongMediaItem(MediaManagerItem): self._updateBackgroundAudio(song, item) editId = song.id self.onSearchTextButtonClick() - elif not self.addSongFromService: + elif add_song and not self.addSongFromService: # Make sure we temporary import formatting tags. song = self.openLyrics.xml_to_song(item.xml_version, True) # If there's any backing tracks, copy them over. if len(item.background_audio) > 0: self._updateBackgroundAudio(song, item) editId = song.id + temporary = True # Update service with correct song id. if editId: Receiver.send_message(u'service_item_update', - u'%s:%s' % (editId, item._uuid)) + u'%s:%s:%s' % (editId, item._uuid, temporary)) def search(self, string): """ From 39bc9238bf821c841039c39ed8f993f45169d4a9 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sat, 10 Dec 2011 08:52:18 +0000 Subject: [PATCH 10/13] Lost temporary edit flag --- openlp/core/lib/serviceitem.py | 1 + 1 file changed, 1 insertion(+) diff --git a/openlp/core/lib/serviceitem.py b/openlp/core/lib/serviceitem.py index 62064dc06..62418f49e 100644 --- a/openlp/core/lib/serviceitem.py +++ b/openlp/core/lib/serviceitem.py @@ -366,6 +366,7 @@ class ServiceItem(object): """ self._uuid = other._uuid self.notes = other.notes + self.temporary_edit = other.temporary_edit # Copy theme over if present. if other.theme is not None: self.theme = other.theme From b07e10282d1fb063d1b9febad3ba3408b0e073e3 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Sat, 10 Dec 2011 14:34:28 +0000 Subject: [PATCH 11/13] clean up service --- openlp/core/lib/eventreceiver.py | 4 ++++ openlp/core/ui/maindisplay.py | 4 ++-- openlp/core/ui/servicemanager.py | 1 + openlp/plugins/songs/songsplugin.py | 14 ++++++++++---- 4 files changed, 17 insertions(+), 6 deletions(-) diff --git a/openlp/core/lib/eventreceiver.py b/openlp/core/lib/eventreceiver.py index 14b6126bc..40cac8e35 100644 --- a/openlp/core/lib/eventreceiver.py +++ b/openlp/core/lib/eventreceiver.py @@ -115,8 +115,12 @@ class EventReceiver(QtCore.QObject): ``slidecontroller_live_stop_loop`` Stop the loop on the main display. + **Servicemanager related signals** + ``servicemanager_new_service`` + A new service is being loaded or created. + ``servicemanager_previous_item`` Display the previous item in the service. diff --git a/openlp/core/ui/maindisplay.py b/openlp/core/ui/maindisplay.py index e439b1db1..328970d45 100644 --- a/openlp/core/ui/maindisplay.py +++ b/openlp/core/ui/maindisplay.py @@ -45,7 +45,7 @@ log = logging.getLogger(__name__) class Display(QtGui.QGraphicsView): """ - This is a general display screen class. Here the general display settings + This is a general display screen class. Here the general display settings will done. It will be used as specialized classes by Main Display and Preview display. """ @@ -66,7 +66,7 @@ class Display(QtGui.QGraphicsView): """ Set up and build the screen base """ - log.debug(u'Start Display base setup (live = %s)' % self.isLive) + log.debug(u'Start Display base setup (live = %s)' % self.isLive) self.setGeometry(self.screen[u'size']) log.debug(u'Setup webView') self.webView = QtWebKit.QWebView(self) diff --git a/openlp/core/ui/servicemanager.py b/openlp/core/ui/servicemanager.py index fa1ccede0..ed5d2ae5b 100644 --- a/openlp/core/ui/servicemanager.py +++ b/openlp/core/ui/servicemanager.py @@ -465,6 +465,7 @@ class ServiceManager(QtGui.QWidget): self.setModified(False) QtCore.QSettings(). \ setValue(u'servicemanager/last file',QtCore.QVariant(u'')) + Receiver.send_message(u'servicemanager_new_service') def saveFile(self): """ diff --git a/openlp/plugins/songs/songsplugin.py b/openlp/plugins/songs/songsplugin.py index 4f0e9d77a..bec9fdf97 100644 --- a/openlp/plugins/songs/songsplugin.py +++ b/openlp/plugins/songs/songsplugin.py @@ -77,6 +77,9 @@ class SongsPlugin(Plugin): action_list.add_action(self.songImportItem, UiStrings().Import) action_list.add_action(self.songExportItem, UiStrings().Export) action_list.add_action(self.toolsReindexItem, UiStrings().Tools) + QtCore.QObject.connect(Receiver.get_receiver(), + QtCore.SIGNAL(u'servicemanager_new_service'), + self.clearTemporarySongs) def addImportMenuItem(self, import_menu): """ @@ -264,10 +267,7 @@ class SongsPlugin(Plugin): Time to tidy up on exit """ log.info(u'Songs Finalising') - # Remove temporary songs - songs = self.manager.get_all_objects(Song, Song.temporary == True) - for song in songs: - self.manager.delete_object(Song, song.id) + self.clearTemporarySongs() # Clean up files and connections self.manager.finalise() self.songImportItem.setVisible(False) @@ -278,3 +278,9 @@ class SongsPlugin(Plugin): action_list.remove_action(self.songExportItem, UiStrings().Export) action_list.remove_action(self.toolsReindexItem, UiStrings().Tools) Plugin.finalise(self) + + def clearTemporarySongs(self): + # Remove temporary songs + songs = self.manager.get_all_objects(Song, Song.temporary == True) + for song in songs: + self.manager.delete_object(Song, song.id) From 4211f196cd180b81c0115fd78287847eb072dd11 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Mon, 12 Dec 2011 17:22:40 +0000 Subject: [PATCH 12/13] Fix review comments --- openlp/core/ui/servicemanager.py | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/openlp/core/ui/servicemanager.py b/openlp/core/ui/servicemanager.py index cf0106bf3..d7df109bb 100644 --- a/openlp/core/ui/servicemanager.py +++ b/openlp/core/ui/servicemanager.py @@ -664,14 +664,14 @@ class ServiceManager(QtGui.QWidget): serviceItem.renderer = self.mainwindow.renderer serviceItem.set_from_service(item, self.servicePath) self.validateItem(serviceItem) - self.loadItem_uuid = 0 + self.load_item_uuid = 0 if serviceItem.is_capable(ItemCapabilities.OnLoadUpdate): Receiver.send_message(u'%s_service_load' % serviceItem.name.lower(), serviceItem) # if the item has been processed - if serviceItem._uuid == self.loadItem_uuid: - serviceItem.edit_id = int(self.loadItem_editId) - serviceItem.temporary_edit = self.loadItem_temporary + if serviceItem._uuid == self.load_item_uuid: + serviceItem.edit_id = int(self.load_item_editId) + serviceItem.temporary_edit = self.load_item_temporary self.addServiceItem(serviceItem, repaint=False) delete_file(p_file) self.setFileName(fileName) @@ -1145,9 +1145,9 @@ class ServiceManager(QtGui.QWidget): Triggered from plugins to update service items. Save the values as they will be used as part of the service load """ - editId, self.loadItem_uuid, temporary = message.split(u':') - self.loadItem_editId = int(editId) - self.loadItem_temporary = str_to_bool(temporary) + editId, self.load_item_uuid, temporary = message.split(u':') + self.load_item_editId = int(editId) + self.load_item_temporary = str_to_bool(temporary) def replaceServiceItem(self, newItem): """ From 143f65f476416134347492773da76dfac5773d1b Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Mon, 12 Dec 2011 18:00:12 +0000 Subject: [PATCH 13/13] Fix review comments --- openlp/core/ui/servicemanager.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/openlp/core/ui/servicemanager.py b/openlp/core/ui/servicemanager.py index d7df109bb..0eb1e77c5 100644 --- a/openlp/core/ui/servicemanager.py +++ b/openlp/core/ui/servicemanager.py @@ -670,7 +670,7 @@ class ServiceManager(QtGui.QWidget): serviceItem.name.lower(), serviceItem) # if the item has been processed if serviceItem._uuid == self.load_item_uuid: - serviceItem.edit_id = int(self.load_item_editId) + serviceItem.edit_id = int(self.load_item_edit_id) serviceItem.temporary_edit = self.load_item_temporary self.addServiceItem(serviceItem, repaint=False) delete_file(p_file) @@ -1145,8 +1145,8 @@ class ServiceManager(QtGui.QWidget): Triggered from plugins to update service items. Save the values as they will be used as part of the service load """ - editId, self.load_item_uuid, temporary = message.split(u':') - self.load_item_editId = int(editId) + edit_id, self.load_item_uuid, temporary = message.split(u':') + self.load_item_edit_id = int(edit_id) self.load_item_temporary = str_to_bool(temporary) def replaceServiceItem(self, newItem):