Fix up serviceitem for better interface

Fix extra rndering cycle from Servicemanager
Fix Image / Custom / Bibles / Songs to use new interface
This commit is contained in:
Tim Bentley 2009-06-05 20:00:57 +01:00
parent 472ef981b6
commit 2157699814
7 changed files with 45 additions and 23 deletions

View File

@ -48,6 +48,7 @@ class ServiceItem():
self.raw_footer = None self.raw_footer = None
self.theme = None self.theme = None
log.debug(u'Service item created for %s ', self.shortname) log.debug(u'Service item created for %s ', self.shortname)
self.service_frames = []
def addIcon(self, icon): def addIcon(self, icon):
self.iconic_representation = buildIcon(icon) self.iconic_representation = buildIcon(icon)
@ -62,23 +63,35 @@ class ServiceItem():
else: else:
self.plugin.render_manager.set_override_theme(self.theme) self.plugin.render_manager.set_override_theme(self.theme)
log.debug(u'Formatting slides') log.debug(u'Formatting slides')
if len(self.frames) == 0 and len(self.raw_slides) > 0 : if self.service_item_type == u'text':
for slide in self.raw_slides: for slide in self.service_frames:
formated = self.plugin.render_manager.format_slide(slide) formated = self.plugin.render_manager.format_slide(slide[u'raw_slide'])
for format in formated: for format in formated:
frame = self.plugin.render_manager.generate_slide(format, self.raw_footer) frame = self.plugin.render_manager.generate_slide(format, self.raw_footer)
self.frames.append({u'title': format, u'image': frame}) self.frames.append({u'title': slide[u'title'], u'image': frame})
elif self.service_item_type == u'command':
self.frames = self.service_frames
self.service_frames = []
elif self.service_item_type == u'image':
self.frames = self.service_frames
self.service_frames = []
else: else:
if len(self.command_files) > 0: assert(0 , u'Invalid value rendere :%s' % self.service_item_type)
pass
def add_from_image(self, frame_title, image):
self.service_item_type = u'image'
self.service_frames.append({u'title': frame_title, u'image': image})
def add_from_text(self, frame_title, raw_slide):
self.service_item_type = u'text'
frame_title = frame_title.split(u'\n')[0]
self.service_frames.append({u'title': frame_title, u'raw_slide': raw_slide})
def add_from_command(self, frame_title, command):
self.service_item_type = u'command'
self.service_frames.append({u'title': frame_title, u'command': command})
def get_parent_node(self):
"""
This method returns a parent node to be inserted into the Service
Manager. At the moment this has to be a QAbstractListModel based class
"""
pass
def get_oos_repr(self): def get_oos_repr(self):
""" """

View File

@ -140,8 +140,8 @@ class ServiceManager(QtGui.QWidget):
count = 0 count = 0
for frame in item.frames: for frame in item.frames:
treewidgetitem1 = QtGui.QTreeWidgetItem(treewidgetitem) treewidgetitem1 = QtGui.QTreeWidgetItem(treewidgetitem)
text = frame[u'title'][0] text = frame[u'title']
treewidgetitem1.setText(0,text[:30]) treewidgetitem1.setText(0,text[:40])
treewidgetitem1.setData(0, QtCore.Qt.UserRole,QtCore.QVariant(count)) treewidgetitem1.setData(0, QtCore.Qt.UserRole,QtCore.QVariant(count))
count = count + 1 count = count + 1

View File

@ -291,7 +291,7 @@ class SlideController(QtGui.QWidget):
""" """
Loads a ServiceItem. Loads a ServiceItem.
""" """
log.debug(u'addServiceItem') log.debug(u'add Service Item')
self.serviceitem = serviceitem self.serviceitem = serviceitem
self.serviceitem.render() self.serviceitem.render()
self.PreviewListData.clear() self.PreviewListData.clear()
@ -309,7 +309,13 @@ class SlideController(QtGui.QWidget):
""" """
Loads a ServiceManagerItem. Loads a ServiceManagerItem.
""" """
self.addServiceItem(serviceitem) log.debug(u'add Service Manager Item')
self.PreviewListData.clear()
self.serviceitem = serviceitem
framenumber = 0
for frame in self.serviceitem.frames:
self.PreviewListData.addRow(frame[u'image'], framenumber)
framenumber += 1
row = self.PreviewListData.createIndex(slideno, 0) row = self.PreviewListData.createIndex(slideno, 0)
if row.isValid(): if row.isValid():
self.PreviewListView.selectionModel().setCurrentIndex(row, self.PreviewListView.selectionModel().setCurrentIndex(row,

View File

@ -397,7 +397,8 @@ class BibleMediaItem(MediaManagerItem):
else: else:
service_item.theme = self.parent.bibles_tab.bible_theme service_item.theme = self.parent.bibles_tab.bible_theme
raw_slides.append(bible_text) raw_slides.append(bible_text)
service_item.raw_slides = raw_slides for slide in raw_slides:
service_item.add_from_text(slide[:30], slide)
service_item.raw_footer = raw_footer service_item.raw_footer = raw_footer
def formatVerse(self, old_chapter, chapter, verse, opening, closing): def formatVerse(self, old_chapter, chapter, verse, opening, closing):

View File

@ -248,5 +248,6 @@ class CustomMediaItem(MediaManagerItem):
raw_footer.append(title + u' '+ credit) raw_footer.append(title + u' '+ credit)
if theme is not None: if theme is not None:
service_item.title = title service_item.title = title
service_item.raw_slides = raw_slides for slide in raw_slides:
service_item.add_from_text(slide[:30], slide)
service_item.raw_footer = raw_footer service_item.raw_footer = raw_footer

View File

@ -150,10 +150,12 @@ class ImageMediaItem(MediaManagerItem):
def generateSlideData(self, service_item): def generateSlideData(self, service_item):
indexes = self.ImageListView.selectedIndexes() indexes = self.ImageListView.selectedIndexes()
service_item.title = u'Images'
for index in indexes: for index in indexes:
filename = self.ImageListData.getFilename(index) filename = self.ImageListData.getFilename(index)
frame = QtGui.QPixmap(str(filename)) frame = QtGui.QPixmap(str(filename))
service_item.frames.append({u'title': filename , u'image': frame}) (path, name) =os.path.split(filename)
service_item.add_from_image(name, frame)
def onImagePreviewClick(self): def onImagePreviewClick(self):
log.debug(u'Image Preview Requested') log.debug(u'Image Preview Requested')

View File

@ -168,7 +168,7 @@ class SongMediaItem(MediaManagerItem):
self.onSongLiveClick)) self.onSongLiveClick))
self.SongListView.addAction(self.contextMenuAction(self.SongListView, self.SongListView.addAction(self.contextMenuAction(self.SongListView,
':/system/system_add.png', translate('SongMediaItem', u'&Add to Service'), ':/system/system_add.png', translate('SongMediaItem', u'&Add to Service'),
self.onSongEditClick)) self.onSongAddClick))
def retranslateUi(self): def retranslateUi(self):
self.SearchTypeLabel.setText(translate('SongMediaItem', u'Search Type:')) self.SearchTypeLabel.setText(translate('SongMediaItem', u'Search Type:'))
@ -258,9 +258,8 @@ class SongMediaItem(MediaManagerItem):
else: else:
service_item.theme = song.theme_name service_item.theme = song.theme_name
verses = song.lyrics.split(u'\n\n') verses = song.lyrics.split(u'\n\n')
for verse in verses: for slide in verses:
raw_slides.append(verse) service_item.add_from_text(slide[:30], slide)
service_item.raw_slides = raw_slides
service_item.title = song.title service_item.title = song.title
raw_footer.append(str(u'%s \n%s \n' % (song.title, song.copyright ))) raw_footer.append(str(u'%s \n%s \n' % (song.title, song.copyright )))
raw_footer.append(song.copyright) raw_footer.append(song.copyright)