Fix wizard after trunk merge and fix a minor display bug.

This commit is contained in:
Patrick Zimmermann 2013-02-12 22:44:33 +01:00
parent e807c9cb93
commit d8cfc4f28a
3 changed files with 30 additions and 23 deletions

View File

@ -200,6 +200,7 @@ class Settings(QtCore.QSettings):
u'shortcuts/songImportItem': [], u'shortcuts/songImportItem': [],
u'shortcuts/themeScreen': [QtGui.QKeySequence(u'T')], u'shortcuts/themeScreen': [QtGui.QKeySequence(u'T')],
u'shortcuts/toolsReindexItem': [], u'shortcuts/toolsReindexItem': [],
u'shortcuts/toolsFindDuplicates': [],
u'shortcuts/toolsAlertItem': [u'F7'], u'shortcuts/toolsAlertItem': [u'F7'],
u'shortcuts/toolsFirstTimeWizard': [], u'shortcuts/toolsFirstTimeWizard': [],
u'shortcuts/toolsOpenDataFolder': [], u'shortcuts/toolsOpenDataFolder': [],

View File

@ -66,7 +66,6 @@ class DuplicateSongRemovalForm(OpenLPWizard):
self.duplicateSongList = [] self.duplicateSongList = []
self.reviewCurrentCount = 0 self.reviewCurrentCount = 0
self.reviewTotalCount = 0 self.reviewTotalCount = 0
self.clipboard = plugin.formParent.clipboard
OpenLPWizard.__init__(self, parent, plugin, u'duplicateSongRemovalWizard', OpenLPWizard.__init__(self, parent, plugin, u'duplicateSongRemovalWizard',
u':/wizards/wizard_duplicateremoval.bmp', False) u':/wizards/wizard_duplicateremoval.bmp', False)
@ -185,7 +184,7 @@ class DuplicateSongRemovalForm(OpenLPWizard):
if self.reviewTotalCount == 0: if self.reviewTotalCount == 0:
self.notifyNoDuplicates() self.notifyNoDuplicates()
elif pageId == self.reviewPageId: elif pageId == self.reviewPageId:
self.nextReviewButtonClicked() self.processCurrentDuplicateEntry()
def notifyNoDuplicates(self): def notifyNoDuplicates(self):
""" """
@ -201,10 +200,10 @@ class DuplicateSongRemovalForm(OpenLPWizard):
def addDuplicatesToSongList(self, searchSong, duplicateSong): def addDuplicatesToSongList(self, searchSong, duplicateSong):
""" """
Inserts a song duplicate (two simliar songs) to the duplicate song list. Inserts a song duplicate (two similar songs) to the duplicate song list.
If one of the two songs is already part of the duplicate song list, If one of the two songs is already part of the duplicate song list,
don't add another duplicate group but add the other song to that group. don't add another duplicate group but add the other song to that group.
Retruns True if at least one of the songs was added, False if both were already Returns True if at least one of the songs was added, False if both were already
member of a group. member of a group.
``searchSong`` ``searchSong``
@ -233,7 +232,7 @@ class DuplicateSongRemovalForm(OpenLPWizard):
break break
if not duplicateGroupFound: if not duplicateGroupFound:
self.duplicateSongList.append([searchSong, duplicateSong]) self.duplicateSongList.append([searchSong, duplicateSong])
duplicateGroupFound = True duplicateAdded = True
return duplicateAdded return duplicateAdded
def onWizardExit(self): def onWizardExit(self):
@ -257,11 +256,11 @@ class DuplicateSongRemovalForm(OpenLPWizard):
on the review page as long as there are more song duplicates to review. on the review page as long as there are more song duplicates to review.
""" """
if self.currentId() == self.reviewPageId: if self.currentId() == self.reviewPageId:
#as long as the duplicate list is not empty we revisit the review page #as long as it's not the last duplicate list entry we revisit the review page
if len(self.duplicateSongList) == 0: if len(self.duplicateSongList) == 1:
return True return True
else: else:
self.nextReviewButtonClicked() self.proceedToNextReview()
return False return False
return OpenLPWizard.validateCurrentPage(self) return OpenLPWizard.validateCurrentPage(self)
@ -301,17 +300,12 @@ class DuplicateSongRemovalForm(OpenLPWizard):
if self.songsHorizontalLayout.count() == 5: if self.songsHorizontalLayout.count() == 5:
self.songsHorizontalLayout.itemAt(2).widget().songRemoveButton.setEnabled(False) self.songsHorizontalLayout.itemAt(2).widget().songRemoveButton.setEnabled(False)
def nextReviewButtonClicked(self): def proceedToNextReview(self):
""" """
Called whenever the "next" button is clicked on the review page. Removes the previous review UI elements and calls processCurrentDuplicateEntry.
Update the review counter in the wizard header, remove all previous
song widgets, add song widgets for the current duplicate group to review,
if it's the last duplicate song group, hide the "next" button and show
the "finish" button.
""" """
# update counter #remove last duplicate group
self.reviewCurrentCount = self.reviewTotalCount - (len(self.duplicateSongList) - 1) self.duplicateSongList.pop()
self.updateReviewCounterText()
# remove all previous elements # remove all previous elements
for i in reversed(range(self.songsHorizontalLayout.count())): for i in reversed(range(self.songsHorizontalLayout.count())):
item = self.songsHorizontalLayout.itemAt(i) item = self.songsHorizontalLayout.itemAt(i)
@ -323,12 +317,24 @@ class DuplicateSongRemovalForm(OpenLPWizard):
widget.setParent(None) widget.setParent(None)
else: else:
self.songsHorizontalLayout.removeItem(item) self.songsHorizontalLayout.removeItem(item)
#add next set of duplicates #process next set of duplicates
self.processCurrentDuplicateEntry()
def processCurrentDuplicateEntry(self):
"""
Update the review counter in the wizard header, add song widgets for
the current duplicate group to review, if it's the last
duplicate song group, hide the "next" button and show the "finish" button.
"""
# update counter
self.reviewCurrentCount = self.reviewTotalCount - (len(self.duplicateSongList) - 1)
self.updateReviewCounterText()
# add song elements to the UI
if len(self.duplicateSongList) > 0: if len(self.duplicateSongList) > 0:
# a stretch doesn't seem to stretch endlessly, so I add two to get enough stetch for 1400x1050 # a stretch doesn't seem to stretch endlessly, so I add two to get enough stetch for 1400x1050
self.songsHorizontalLayout.addStretch() self.songsHorizontalLayout.addStretch()
self.songsHorizontalLayout.addStretch() self.songsHorizontalLayout.addStretch()
for duplicate in self.duplicateSongList.pop(0): for duplicate in self.duplicateSongList[-1]:
songReviewWidget = SongReviewWidget(self.reviewPage, duplicate) songReviewWidget = SongReviewWidget(self.reviewPage, duplicate)
QtCore.QObject.connect(songReviewWidget, QtCore.QObject.connect(songReviewWidget,
QtCore.SIGNAL(u'songRemoveButtonClicked(PyQt_PyObject)'), QtCore.SIGNAL(u'songRemoveButtonClicked(PyQt_PyObject)'),
@ -337,7 +343,7 @@ class DuplicateSongRemovalForm(OpenLPWizard):
self.songsHorizontalLayout.addStretch() self.songsHorizontalLayout.addStretch()
self.songsHorizontalLayout.addStretch() self.songsHorizontalLayout.addStretch()
#change next button to finish button on last review #change next button to finish button on last review
if len(self.duplicateSongList) == 0: if len(self.duplicateSongList) == 1:
self.button(QtGui.QWizard.FinishButton).show() self.button(QtGui.QWizard.FinishButton).show()
self.button(QtGui.QWizard.FinishButton).setEnabled(True) self.button(QtGui.QWizard.FinishButton).setEnabled(True)
self.button(QtGui.QWizard.NextButton).hide() self.button(QtGui.QWizard.NextButton).hide()

View File

@ -153,7 +153,7 @@ class SongsPlugin(Plugin):
visible=False, triggers=self.onToolsReindexItemTriggered) visible=False, triggers=self.onToolsReindexItemTriggered)
tools_menu.addAction(self.toolsReindexItem) tools_menu.addAction(self.toolsReindexItem)
self.toolsFindDuplicates = create_action(tools_menu, u'toolsFindDuplicates', self.toolsFindDuplicates = create_action(tools_menu, u'toolsFindDuplicates',
text=translate('SongsPlugin', 'Find &duplicate songs'), text=translate('SongsPlugin', 'Find &Duplicate Songs'),
statustip=translate('SongsPlugin', statustip=translate('SongsPlugin',
'Find and remove duplicate songs in the song database.'), 'Find and remove duplicate songs in the song database.'),
visible=False, triggers=self.onToolsFindDuplicatesTriggered) visible=False, triggers=self.onToolsFindDuplicatesTriggered)
@ -181,7 +181,7 @@ class SongsPlugin(Plugin):
""" """
Search for duplicates in the song database. Search for duplicates in the song database.
""" """
DuplicateSongRemovalForm(self.formParent, self).exec_() DuplicateSongRemovalForm(self.main_window, self).exec_()
def onSongImportItemClicked(self): def onSongImportItemClicked(self):
if self.mediaItem: if self.mediaItem: