This commit is contained in:
Raoul Snyman 2016-04-29 22:15:41 +02:00
commit e505950d3f
2 changed files with 16 additions and 17 deletions

View File

@ -21,7 +21,6 @@
############################################################################### ###############################################################################
import logging import logging
import re
import os import os
import shutil import shutil
@ -32,6 +31,7 @@ from openlp.core.common import Registry, AppLocation, Settings, check_directory_
from openlp.core.lib import MediaManagerItem, ItemCapabilities, PluginStatus, ServiceItemContext, \ from openlp.core.lib import MediaManagerItem, ItemCapabilities, PluginStatus, ServiceItemContext, \
check_item_selected, create_separated_list check_item_selected, create_separated_list
from openlp.core.lib.ui import create_widget_action from openlp.core.lib.ui import create_widget_action
from openlp.core.utils import get_natural_key
from openlp.plugins.songs.forms.editsongform import EditSongForm from openlp.plugins.songs.forms.editsongform import EditSongForm
from openlp.plugins.songs.forms.songmaintenanceform import SongMaintenanceForm from openlp.plugins.songs.forms.songmaintenanceform import SongMaintenanceForm
from openlp.plugins.songs.forms.songimportform import SongImportForm from openlp.plugins.songs.forms.songimportform import SongImportForm
@ -251,23 +251,23 @@ class SongMediaItem(MediaManagerItem):
self.list_view.clear() self.list_view.clear()
search_keywords = search_keywords.rpartition(' ') search_keywords = search_keywords.rpartition(' ')
search_book = search_keywords[0] search_book = search_keywords[0] + '%'
search_entry = re.sub(r'[^0-9]', '', search_keywords[2]) search_entry = search_keywords[2] + '%'
search_results = (self.plugin.manager.session.query(SongBookEntry.entry, Book.name, Song.title, Song.id)
songbook_entries = (self.plugin.manager.session.query(SongBookEntry) .join(Song)
.join(Book) .join(Book)
.order_by(Book.name) .filter(Book.name.like(search_book), SongBookEntry.entry.like(search_entry),
.order_by(SongBookEntry.entry)) Song.temporary.is_(False)).all())
for songbook_entry in songbook_entries:
if songbook_entry.song.temporary: def get_songbook_key(result):
continue """Get the key to sort by"""
if search_book.lower() not in songbook_entry.songbook.name.lower(): return (get_natural_key(result[1]), get_natural_key(result[0]), get_natural_key(result[2]))
continue
if search_entry not in songbook_entry.entry: search_results.sort(key=get_songbook_key)
continue for result in search_results:
song_detail = '%s #%s: %s' % (songbook_entry.songbook.name, songbook_entry.entry, songbook_entry.song.title) song_detail = '%s #%s: %s' % (result[1], result[0], result[2])
song_name = QtWidgets.QListWidgetItem(song_detail) song_name = QtWidgets.QListWidgetItem(song_detail)
song_name.setData(QtCore.Qt.UserRole, songbook_entry.song.id) song_name.setData(QtCore.Qt.UserRole, result[3])
self.list_view.addItem(song_name) self.list_view.addItem(song_name)
def on_clear_text_button_click(self): def on_clear_text_button_click(self):

View File

@ -73,4 +73,3 @@ class TestOpenLPImport(TestCase):
self.assertIsNone(importer.do_import(), 'do_import should return None when import_source is not a list') self.assertIsNone(importer.do_import(), 'do_import should return None when import_source is not a list')
self.assertEqual(mocked_import_wizard.progress_bar.setMaximum.called, False, self.assertEqual(mocked_import_wizard.progress_bar.setMaximum.called, False,
'setMaximum on import_wizard.progress_bar should not have been called') 'setMaximum on import_wizard.progress_bar should not have been called')