forked from openlp/openlp
corrected names and filter the songs first
This commit is contained in:
commit
a8e8cd891d
@ -381,64 +381,64 @@ class SongMaintenanceForm(QtGui.QDialog, Ui_SongMaintenanceDialog):
|
|||||||
book.name = temp_name
|
book.name = temp_name
|
||||||
book.publisher = temp_publisher
|
book.publisher = temp_publisher
|
||||||
|
|
||||||
def mergeAuthors(self, existing_author):
|
def mergeAuthors(self, old_author):
|
||||||
'''
|
'''
|
||||||
Merges two authors into one author.
|
Merges two authors into one author.
|
||||||
|
|
||||||
``existing_author``
|
``old_author``
|
||||||
The author which will be deleted afterwards.
|
The author which will be deleted afterwards.
|
||||||
'''
|
'''
|
||||||
new_author = self.songmanager.get_object_filtered(Author,
|
existing_author = self.songmanager.get_object_filtered(Author,
|
||||||
and_(Author.first_name == existing_author.first_name,
|
and_(Author.first_name == old_author.first_name,
|
||||||
Author.last_name == existing_author.last_name,
|
Author.last_name == old_author.last_name,
|
||||||
Author.display_name == existing_author.display_name))
|
Author.display_name == old_author.display_name))
|
||||||
songs = self.songmanager.get_all_objects(Song)
|
songs = self.songmanager.get_all_objects_filtered(Song,
|
||||||
|
Song.authors.contains(old_author))
|
||||||
for song in songs:
|
for song in songs:
|
||||||
if existing_author in song.authors:
|
# We check if the song has already existing_author as author. If
|
||||||
# We check if the song has already the new_author as author.
|
# that is not the case we add it.
|
||||||
# If that is not the case we add it.
|
if existing_author not in song.authors:
|
||||||
if new_author not in song.authors:
|
song.authors.append(existing_author)
|
||||||
song.authors.append(new_author)
|
song.authors.remove(old_author)
|
||||||
song.authors.remove(existing_author)
|
self.songmanager.save_object(song)
|
||||||
self.songmanager.save_object(song)
|
self.songmanager.delete_object(Author, old_author.id)
|
||||||
self.songmanager.delete_object(Author, existing_author.id)
|
|
||||||
|
|
||||||
def mergeTopics(self, existing_topic):
|
def mergeTopics(self, old_topic):
|
||||||
'''
|
'''
|
||||||
Merges two topics into one topic.
|
Merges two topics into one topic.
|
||||||
|
|
||||||
``existing_topic``
|
``old_topic``
|
||||||
The topic which will be deleted afterwards.
|
The topic which will be deleted afterwards.
|
||||||
'''
|
'''
|
||||||
new_topic = self.songmanager.get_object_filtered(Topic,
|
existing_topic = self.songmanager.get_object_filtered(Topic,
|
||||||
Topic.name == existing_topic.name)
|
Topic.name == old_topic.name)
|
||||||
songs = self.songmanager.get_all_objects(Song)
|
songs = self.songmanager.get_all_objects_filtered(Song,
|
||||||
|
Song.topics.contains(old_topic))
|
||||||
for song in songs:
|
for song in songs:
|
||||||
if existing_topic in song.topics:
|
# We check if the song has already existing_topic as topic. If that
|
||||||
# We check if the song has already the new_topic as topic.
|
# is not the case we add it.
|
||||||
# If that is not the case we add it.
|
if existing_topic not in song.topics:
|
||||||
if new_topic not in song.topics:
|
song.topics.append(existing_topic)
|
||||||
song.topics.append(new_topic)
|
song.topics.remove(old_topic)
|
||||||
song.topics.remove(existing_topic)
|
self.songmanager.save_object(song)
|
||||||
self.songmanager.save_object(song)
|
self.songmanager.delete_object(Topic, old_topic.id)
|
||||||
self.songmanager.delete_object(Topic, existing_topic.id)
|
|
||||||
|
|
||||||
def mergeBooks(self, existing_book):
|
def mergeBooks(self, old_book):
|
||||||
'''
|
'''
|
||||||
Merges two books into one book.
|
Merges two books into one book.
|
||||||
|
|
||||||
``existing_book``
|
``old_book``
|
||||||
The book which will be deleted afterwards.
|
The book which will be deleted afterwards.
|
||||||
'''
|
'''
|
||||||
new_book = self.songmanager.get_object_filtered(Book,
|
existing_book = self.songmanager.get_object_filtered(Book,
|
||||||
and_(Book.name == existing_book.name,
|
and_(Book.name == old_book.name,
|
||||||
Book.publisher == existing_book.publisher))
|
Book.publisher == old_book.publisher))
|
||||||
songs = self.songmanager.get_all_objects_filtered(Song,
|
songs = self.songmanager.get_all_objects_filtered(Song,
|
||||||
Song.song_book_id == existing_book.id)
|
Song.song_book_id == old_book.id)
|
||||||
for song in songs:
|
for song in songs:
|
||||||
song.song_book_id = new_book.id
|
song.song_book_id = existing_book.id
|
||||||
self.songmanager.save_object(song)
|
self.songmanager.save_object(song)
|
||||||
self.songmanager.delete_object(Book, existing_book.id)
|
self.songmanager.delete_object(Book, old_book.id)
|
||||||
|
|
||||||
def onAuthorDeleteButtonClick(self):
|
def onAuthorDeleteButtonClick(self):
|
||||||
"""
|
"""
|
||||||
|
Loading…
Reference in New Issue
Block a user