openlp-core team mailing list archive
-
openlp-core team
-
Mailing list archive
-
Message #07361
[Merge] lp:~raoul-snyman/openlp/bug-709975 into lp:openlp
Raoul Snyman has proposed merging lp:~raoul-snyman/openlp/bug-709975 into lp:openlp.
Requested reviews:
OpenLP Core (openlp-core)
Related bugs:
Bug #709975 in OpenLP: "RFE chapter and verses"
https://bugs.launchpad.net/openlp/+bug/709975
For more details, see:
https://code.launchpad.net/~raoul-snyman/openlp/bug-709975/+merge/54134
Added smart footers to Bibles (see bug #709975).
--
https://code.launchpad.net/~raoul-snyman/openlp/bug-709975/+merge/54134
Your team OpenLP Core is requested to review the proposed merge of lp:~raoul-snyman/openlp/bug-709975 into lp:openlp.
=== modified file 'openlp/plugins/bibles/lib/__init__.py'
--- openlp/plugins/bibles/lib/__init__.py 2011-02-24 05:47:38 +0000
+++ openlp/plugins/bibles/lib/__init__.py 2011-03-20 21:02:27 +0000
@@ -268,6 +268,7 @@
return len(self.verselist) > 0
+from versereferencelist import VerseReferenceList
from manager import BibleManager
from biblestab import BiblesTab
from mediaitem import BibleMediaItem
=== modified file 'openlp/plugins/bibles/lib/mediaitem.py'
--- openlp/plugins/bibles/lib/mediaitem.py 2011-03-10 17:56:42 +0000
+++ openlp/plugins/bibles/lib/mediaitem.py 2011-03-20 21:02:27 +0000
@@ -35,7 +35,7 @@
media_item_combo_box, critical_error_message_box
from openlp.plugins.bibles.forms import BibleImportForm
from openlp.plugins.bibles.lib import LayoutStyle, DisplayStyle, \
- get_reference_match
+ VerseReferenceList, get_reference_match
log = logging.getLogger(__name__)
@@ -637,6 +637,7 @@
old_chapter = -1
raw_slides = []
raw_title = []
+ verses = VerseReferenceList()
for item in items:
bitem = self.listView.item(item.row())
book = self._decodeQtObject(bitem, 'book')
@@ -653,15 +654,9 @@
second_permissions = \
self._decodeQtObject(bitem, 'second_permissions')
second_text = self._decodeQtObject(bitem, 'second_text')
+ verses.add(book, chapter, verse, version, copyright, permissions)
verse_text = self.formatVerse(old_chapter, chapter, verse)
- footer = u'%s (%s %s %s)' % (book, version, copyright, permissions)
- if footer not in service_item.raw_footer:
- service_item.raw_footer.append(footer)
if second_bible:
- footer = u'%s (%s %s %s)' % (book, second_version,
- second_copyright, second_permissions)
- if footer not in service_item.raw_footer:
- service_item.raw_footer.append(footer)
bible_text = u'%s %s\n\n%s %s' % (verse_text, text,
verse_text, second_text)
raw_slides.append(bible_text.rstrip())
@@ -684,6 +679,12 @@
start_item = item
old_item = item
old_chapter = chapter
+ # Add footer
+ service_item.raw_footer.append(verses.format_verses())
+ if second_bible:
+ verses.add_version(second_version, second_copyright,
+ second_permissions)
+ service_item.raw_footer.append(verses.format_versions())
raw_title.append(self.formatTitle(start_item, item))
# If there are no more items we check whether we have to add bible_text.
if bible_text:
=== added file 'openlp/plugins/bibles/lib/versereferencelist.py'
--- openlp/plugins/bibles/lib/versereferencelist.py 1970-01-01 00:00:00 +0000
+++ openlp/plugins/bibles/lib/versereferencelist.py 2011-03-20 21:02:27 +0000
@@ -0,0 +1,99 @@
+# -*- coding: utf-8 -*-
+# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
+
+###############################################################################
+# OpenLP - Open Source Lyrics Projection #
+# --------------------------------------------------------------------------- #
+# Copyright (c) 2008-2011 Raoul Snyman #
+# Portions copyright (c) 2008-2011 Tim Bentley, Jonathan Corwin, Michael #
+# Gorven, Scott Guerrieri, Meinert Jordan, Armin Köhler, Andreas Preikschat, #
+# Christian Richter, Philip Ridout, Maikel Stuivenberg, Martin Thompson, Jon #
+# Tibble, Carsten Tinggaard, Frode Woldsund #
+# --------------------------------------------------------------------------- #
+# 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 #
+###############################################################################
+
+class VerseReferenceList(object):
+ """
+ The VerseReferenceList class encapsulates a list of verse references, but
+ maintains the order in which they were added.
+ """
+
+ def __init__(self):
+ self.verse_list = []
+ self.version_list = []
+ self.current_index = -1
+
+ def add(self, book, chapter, verse, version, copyright, permission):
+ self.add_version(version, copyright, permission)
+ if not self.verse_list or \
+ self.verse_list[self.current_index][u'book'] != book:
+ self.verse_list.append({u'version': version, u'book': book,
+ u'chapter': chapter, u'start': verse, u'end': verse})
+ self.current_index += 1
+ elif self.verse_list[self.current_index][u'chapter'] != chapter:
+ self.verse_list.append({u'version': version, u'book': book,
+ u'chapter': chapter, u'start': verse, u'end': verse})
+ self.current_index += 1
+ elif (self.verse_list[self.current_index][u'end'] + 1) == verse:
+ self.verse_list[self.current_index][u'end'] = verse
+ else:
+ self.verse_list.append({u'version': version, u'book': book,
+ u'chapter': chapter, u'start': verse, u'end': verse})
+ self.current_index += 1
+
+ def add_version(self, version, copyright, permission):
+ for bible_version in self.version_list:
+ if bible_version[u'version'] == version:
+ return
+ self.version_list.append({u'version': version, u'copyright': copyright,
+ u'permission': permission})
+
+ def format_verses(self):
+ result = u''
+ for index, verse in enumerate(self.verse_list):
+ if index == 0:
+ result = u'%s %s:%s' % (verse[u'book'], verse[u'chapter'],
+ verse[u'start'])
+ if verse[u'start'] != verse[u'end']:
+ result = u'%s-%s' % (result, verse[u'end'])
+ continue
+ prev = index - 1
+ if self.verse_list[prev][u'version'] != verse[u'version']:
+ result = u'%s (%s)' % (result, verse[u'version'])
+ result = result + u', '
+ if self.verse_list[prev][u'book'] != verse[u'book']:
+ result = u'%s%s %s:' % (result, verse[u'book'],
+ verse[u'chapter'])
+ elif self.verse_list[prev][u'chapter'] != verse[u'chapter']:
+ result = u'%s%s:' % (result, verse[u'chapter'])
+ result = result + str(verse[u'start'])
+ if verse[u'start'] != verse[u'end']:
+ result = u'%s-%s' % (result, verse[u'end'])
+ if len(self.version_list) > 1:
+ result = u'%s (%s)' % (result, verse[u'version'])
+ return result
+
+ def format_versions(self):
+ result = u''
+ for index, version in enumerate(self.version_list):
+ if index > 0:
+ if result[-1] not in [u';', u',', u'.']:
+ result = result + u';'
+ result = result + u' '
+ result = u'%s%s, %s' % (result, version[u'version'],
+ version[u'copyright'])
+ if version[u'permission'].strip():
+ result = result + u', ' + version[u'permission']
+ return result
Follow ups