forked from openlp/openlp
Fix up quote problems in SongXMLHandler
Add MVC to Custom Add Update to Custom Remove xml1.py as has served it's purpose bzr-revno: 416
This commit is contained in:
parent
eaa1aa81fd
commit
268f6361b5
@ -18,14 +18,14 @@ class SongXMLBuilder():
|
|||||||
|
|
||||||
def new_document(self):
|
def new_document(self):
|
||||||
# Create the <song> base element
|
# Create the <song> base element
|
||||||
self.song = self.song_xml.createElement("song")
|
self.song = self.song_xml.createElement(u'song')
|
||||||
self.song_xml.appendChild(self.song)
|
self.song_xml.appendChild(self.song)
|
||||||
self.song.setAttribute("version", "1.0")
|
self.song.setAttribute(u'version', u'1.0')
|
||||||
|
|
||||||
def add_lyrics_to_song(self):
|
def add_lyrics_to_song(self):
|
||||||
# Create the main <lyrics> element
|
# Create the main <lyrics> element
|
||||||
self.lyrics = self.song_xml.createElement("lyrics")
|
self.lyrics = self.song_xml.createElement(u'lyrics')
|
||||||
self.lyrics.setAttribute("language", "en")
|
self.lyrics.setAttribute(u'language', u'en')
|
||||||
self.song.appendChild(self.lyrics)
|
self.song.appendChild(self.lyrics)
|
||||||
|
|
||||||
def add_verse_to_lyrics(self, type, number, content):
|
def add_verse_to_lyrics(self, type, number, content):
|
||||||
@ -34,9 +34,9 @@ class SongXMLBuilder():
|
|||||||
number - number of item eg verse 1
|
number - number of item eg verse 1
|
||||||
content - the text to be stored
|
content - the text to be stored
|
||||||
"""
|
"""
|
||||||
verse = self.song_xml.createElement("verse")
|
verse = self.song_xml.createElement(u'verse')
|
||||||
verse.setAttribute("type", type)
|
verse.setAttribute(u'type', type)
|
||||||
verse.setAttribute('label', number)
|
verse.setAttribute(u'label', number)
|
||||||
self.lyrics.appendChild(verse)
|
self.lyrics.appendChild(verse)
|
||||||
|
|
||||||
# add data as a CDATA section
|
# add data as a CDATA section
|
||||||
@ -60,7 +60,7 @@ class SongXMLParser():
|
|||||||
iter=self.song_xml.getiterator()
|
iter=self.song_xml.getiterator()
|
||||||
verse_list = []
|
verse_list = []
|
||||||
for element in iter:
|
for element in iter:
|
||||||
if element.tag == 'verse':
|
if element.tag == u'verse':
|
||||||
verse_list.append([element.attrib, element.text])
|
verse_list.append([element.attrib, element.text])
|
||||||
return verse_list
|
return verse_list
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@ Place, Suite 330, Boston, MA 02111-1307 USA
|
|||||||
from PyQt4 import Qt, QtCore, QtGui
|
from PyQt4 import Qt, QtCore, QtGui
|
||||||
|
|
||||||
from editcustomdialog import Ui_customEditDialog
|
from editcustomdialog import Ui_customEditDialog
|
||||||
from openlp.core.lib import SongXMLBuilder
|
from openlp.core.lib import SongXMLBuilder, SongXMLParser
|
||||||
from openlp.plugins.custom.lib.models import CustomSlide
|
from openlp.plugins.custom.lib.models import CustomSlide
|
||||||
|
|
||||||
class EditCustomForm(QtGui.QDialog, Ui_customEditDialog):
|
class EditCustomForm(QtGui.QDialog, Ui_customEditDialog):
|
||||||
@ -55,6 +55,25 @@ class EditCustomForm(QtGui.QDialog, Ui_customEditDialog):
|
|||||||
self.VerseListView.setAlternatingRowColors(True)
|
self.VerseListView.setAlternatingRowColors(True)
|
||||||
#self.savebutton = self.ButtonBox.button(QtGui.QDialogButtonBox.Save)
|
#self.savebutton = self.ButtonBox.button(QtGui.QDialogButtonBox.Save)
|
||||||
|
|
||||||
|
def initialise(self):
|
||||||
|
self.valid = True
|
||||||
|
self.DeleteButton.setEnabled(False)
|
||||||
|
self.EditButton.setEnabled(False)
|
||||||
|
self.SaveButton.setEnabled(False)
|
||||||
|
self.VerseTextEdit.clear()
|
||||||
|
self.VerseListView.clear()
|
||||||
|
|
||||||
|
def loadCustom(self, id):
|
||||||
|
self.customSlide = self.custommanager.get_custom(id)
|
||||||
|
self.TitleEdit.setText(self.customSlide.title)
|
||||||
|
self.CreditEdit.setText(self.customSlide.title)
|
||||||
|
|
||||||
|
songXML=SongXMLParser(self.customSlide.text)
|
||||||
|
verseList = songXML.get_verses()
|
||||||
|
for verse in verseList:
|
||||||
|
self.VerseListView.addItem(verse[1])
|
||||||
|
self.validate()
|
||||||
|
|
||||||
def accept(self):
|
def accept(self):
|
||||||
self.validate()
|
self.validate()
|
||||||
if self.valid:
|
if self.valid:
|
||||||
@ -66,11 +85,12 @@ class EditCustomForm(QtGui.QDialog, Ui_customEditDialog):
|
|||||||
sxml.add_verse_to_lyrics(u'custom', str(count), str(self.VerseListView.item(i).text()))
|
sxml.add_verse_to_lyrics(u'custom', str(count), str(self.VerseListView.item(i).text()))
|
||||||
count += 1
|
count += 1
|
||||||
sxml.dump_xml()
|
sxml.dump_xml()
|
||||||
customSlide = CustomSlide()
|
if self.customSlide == None:
|
||||||
customSlide.title = unicode(self.TitleEdit.displayText())
|
self.customSlide = CustomSlide()
|
||||||
customSlide.text = unicode(sxml.extract_xml())
|
self.customSlide.title = unicode(self.TitleEdit.displayText())
|
||||||
customSlide.credits = unicode(self.CreditEdit.displayText())
|
self.customSlide.text = unicode(sxml.extract_xml())
|
||||||
self.custommanager.save_slide(customSlide)
|
self.customSlide.credits = unicode(self.CreditEdit.displayText())
|
||||||
|
self.custommanager.save_slide(self.customSlide)
|
||||||
self.close()
|
self.close()
|
||||||
|
|
||||||
def rejected(self):
|
def rejected(self):
|
||||||
@ -134,16 +154,6 @@ class EditCustomForm(QtGui.QDialog, Ui_customEditDialog):
|
|||||||
if invalid == 1:
|
if invalid == 1:
|
||||||
self.valid = False
|
self.valid = False
|
||||||
|
|
||||||
def initialise(self):
|
|
||||||
self.valid = True
|
|
||||||
self.DeleteButton.setEnabled(False)
|
|
||||||
self.EditButton.setEnabled(False)
|
|
||||||
self.SaveButton.setEnabled(False)
|
|
||||||
# list = self.songmanager.get_authors()
|
|
||||||
# self.AuthorsSelectionComboItem.clear()
|
|
||||||
# for i in list:
|
|
||||||
# self.AuthorsSelectionComboItem.addItem( i.display_name)
|
|
||||||
|
|
||||||
def loadCustomItem(self, id):
|
def loadCustomItem(self, id):
|
||||||
pass
|
pass
|
||||||
#self.item = self.songmanager.get_song(id)
|
#self.item = self.songmanager.get_song(id)
|
||||||
|
@ -75,7 +75,7 @@ class CustomManager():
|
|||||||
Returns the details of a song
|
Returns the details of a song
|
||||||
"""
|
"""
|
||||||
if id is None:
|
if id is None:
|
||||||
return CustomeSlide()
|
return CustomSlide()
|
||||||
else:
|
else:
|
||||||
return self.session.query(CustomSlide).get(id)
|
return self.session.query(CustomSlide).get(id)
|
||||||
|
|
||||||
@ -92,6 +92,15 @@ class CustomManager():
|
|||||||
except:
|
except:
|
||||||
log.debug('Custom Slide failed')
|
log.debug('Custom Slide failed')
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
def get_custom(self, id=None):
|
||||||
|
"""
|
||||||
|
Returns the details of a Custom Slide
|
||||||
|
"""
|
||||||
|
if id is None:
|
||||||
|
return CustomSlide()
|
||||||
|
else:
|
||||||
|
return self.session.query(CustomSlide).get(id)
|
||||||
#
|
#
|
||||||
# def delete_song(self, song):
|
# def delete_song(self, song):
|
||||||
# try:
|
# try:
|
||||||
|
@ -21,10 +21,11 @@ import logging
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
|
from openlp.core import translate
|
||||||
from openlp.core.lib import MediaManagerItem
|
from openlp.core.lib import MediaManagerItem
|
||||||
from openlp.core.resources import *
|
from openlp.core.resources import *
|
||||||
|
|
||||||
#from openlp.plugins.custom.lib import TextItemData
|
from openlp.plugins.custom.lib import TextListData
|
||||||
|
|
||||||
|
|
||||||
class CustomMediaItem(MediaManagerItem):
|
class CustomMediaItem(MediaManagerItem):
|
||||||
@ -95,8 +96,8 @@ class CustomMediaItem(MediaManagerItem):
|
|||||||
|
|
||||||
self.CustomListView = QtGui.QListView()
|
self.CustomListView = QtGui.QListView()
|
||||||
self.CustomListView.setAlternatingRowColors(True)
|
self.CustomListView.setAlternatingRowColors(True)
|
||||||
# self.CustomListData = TextListData()
|
self.CustomListData = TextListData()
|
||||||
# self.CustomListView.setModel(self.CustomListData)
|
self.CustomListView.setModel(self.CustomListData)
|
||||||
|
|
||||||
self.PageLayout.addWidget(self.CustomListView)
|
self.PageLayout.addWidget(self.CustomListView)
|
||||||
|
|
||||||
@ -110,9 +111,12 @@ class CustomMediaItem(MediaManagerItem):
|
|||||||
QtCore.QObject.connect(self.CustomListView,
|
QtCore.QObject.connect(self.CustomListView,
|
||||||
QtCore.SIGNAL("itemPressed(QTableWidgetItem * item)"), self.onCustomSelected)
|
QtCore.SIGNAL("itemPressed(QTableWidgetItem * item)"), self.onCustomSelected)
|
||||||
|
|
||||||
# #define and add the context menu
|
#define and add the context menu
|
||||||
self.CustomListView.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
|
self.CustomListView.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
|
||||||
#
|
self.CustomListView.addAction(self.contextMenuAction(self.CustomListView,
|
||||||
|
':/custom/custom_edit.png', translate('CustomMediaItem', u'&Edit Custom'),
|
||||||
|
self.onCustomEditClick))
|
||||||
|
self.CustomListView.addAction(self.contextMenuSeparator(self.CustomListView))
|
||||||
self.CustomListView.addAction(self.contextMenuAction(
|
self.CustomListView.addAction(self.contextMenuAction(
|
||||||
self.CustomListView, ':/system/system_preview.png',
|
self.CustomListView, ':/system/system_preview.png',
|
||||||
"&Preview Custom", self.onCustomPreviewClick))
|
"&Preview Custom", self.onCustomPreviewClick))
|
||||||
@ -128,9 +132,7 @@ class CustomMediaItem(MediaManagerItem):
|
|||||||
|
|
||||||
def loadCustomList(self, list):
|
def loadCustomList(self, list):
|
||||||
for CustomSlide in list:
|
for CustomSlide in list:
|
||||||
print CustomSlide.title
|
self.CustomListData.addRow(CustomSlide.id,CustomSlide.title)
|
||||||
# for CustomSlide in list:
|
|
||||||
# self.CustomListData.addRow(CustomSlide.id,CustomSlide.title)
|
|
||||||
|
|
||||||
def onClearTextButtonClick(self):
|
def onClearTextButtonClick(self):
|
||||||
"""
|
"""
|
||||||
@ -154,12 +156,14 @@ class CustomMediaItem(MediaManagerItem):
|
|||||||
|
|
||||||
def onCustomNewClick(self):
|
def onCustomNewClick(self):
|
||||||
self.parent.edit_custom_form.exec_()
|
self.parent.edit_custom_form.exec_()
|
||||||
|
self.initialise()
|
||||||
|
|
||||||
def onCustomEditClick(self):
|
def onCustomEditClick(self):
|
||||||
current_row = self.CustomListView.currentRow()
|
indexes = self.CustomListView.selectedIndexes()
|
||||||
id = int(self.CustomListView.item(current_row, 0).text())
|
for index in indexes:
|
||||||
self.edit_Custom_form.loadCustom(id)
|
self.parent.edit_custom_form.loadCustom(self.CustomListData.getId(index))
|
||||||
self.edit_Custom_form.exec_()
|
self.parent.edit_custom_form.exec_()
|
||||||
|
self.initialise()
|
||||||
|
|
||||||
def onCustomDeleteClick(self):
|
def onCustomDeleteClick(self):
|
||||||
pass
|
pass
|
||||||
|
@ -38,8 +38,6 @@ class TextListData(QAbstractListModel):
|
|||||||
if row > len(self.items): # if the last row is selected and deleted, we then get called with an empty row!
|
if row > len(self.items): # if the last row is selected and deleted, we then get called with an empty row!
|
||||||
return QVariant()
|
return QVariant()
|
||||||
if role==Qt.DisplayRole:
|
if role==Qt.DisplayRole:
|
||||||
retval= self.items[row][2]
|
|
||||||
elif role == Qt.DecorationRole:
|
|
||||||
retval= self.items[row][1]
|
retval= self.items[row][1]
|
||||||
elif role == Qt.ToolTipRole:
|
elif role == Qt.ToolTipRole:
|
||||||
retval= self.items[row][0]
|
retval= self.items[row][0]
|
||||||
@ -57,7 +55,7 @@ class TextListData(QAbstractListModel):
|
|||||||
|
|
||||||
def getId(self, index):
|
def getId(self, index):
|
||||||
row = index.row()
|
row = index.row()
|
||||||
return self.item[row][0]
|
return self.items[row][0]
|
||||||
|
|
||||||
if __name__=="__main__":
|
if __name__=="__main__":
|
||||||
sxml=TextListData()
|
sxml=TextListData()
|
||||||
|
83
xml1.py
83
xml1.py
@ -1,83 +0,0 @@
|
|||||||
from xml.dom.minidom import Document
|
|
||||||
from xml.etree.ElementTree import ElementTree, XML, dump
|
|
||||||
"""
|
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<song version="1.0">
|
|
||||||
<lyrics language="en">
|
|
||||||
<verse type="chorus" label="1">
|
|
||||||
<![CDATA[ ... ]]>
|
|
||||||
</verse>
|
|
||||||
</lyrics>
|
|
||||||
</song>
|
|
||||||
|
|
||||||
"""
|
|
||||||
class SongXMLBuilder():
|
|
||||||
def __init__(self):
|
|
||||||
# Create the minidom document
|
|
||||||
self.song_xml = Document()
|
|
||||||
|
|
||||||
def new_document(self):
|
|
||||||
# Create the <song> base element
|
|
||||||
self.song = self.song_xml.createElement(u'song')
|
|
||||||
self.song_xml.appendChild(self.song)
|
|
||||||
self.song.setAttribute(u'version', u'1.0')
|
|
||||||
|
|
||||||
def add_lyrics_to_song(self):
|
|
||||||
# Create the main <lyrics> element
|
|
||||||
self.lyrics = self.song_xml.createElement(u'lyrics')
|
|
||||||
self.lyrics.setAttribute(u'language', u'en')
|
|
||||||
self.song.appendChild(self.lyrics)
|
|
||||||
|
|
||||||
def add_verse_to_lyrics(self, type, label, content):
|
|
||||||
"""
|
|
||||||
type - type of verse (Chorus, Verse , Bridge, Custom etc
|
|
||||||
label - label of item eg verse 1
|
|
||||||
content - the text to be stored
|
|
||||||
"""
|
|
||||||
verse = self.song_xml.createElement(u'verse')
|
|
||||||
verse.setAttribute(u'type', type)
|
|
||||||
verse.setAttribute(u'label', label)
|
|
||||||
self.lyrics.appendChild(verse)
|
|
||||||
|
|
||||||
# add data as a CDATA section
|
|
||||||
cds = self.song_xml.createCDATASection(content)
|
|
||||||
verse.appendChild(cds)
|
|
||||||
|
|
||||||
def dump_xml(self):
|
|
||||||
# Debugging aid to see what we have
|
|
||||||
print self.song_xml.toprettyxml(indent=u' ')
|
|
||||||
|
|
||||||
def extract_xml(self):
|
|
||||||
# Print our newly created XML
|
|
||||||
return self.song_xml.toxml()
|
|
||||||
|
|
||||||
class SongXMLParser():
|
|
||||||
def __init__(self, xml):
|
|
||||||
self.song_xml = ElementTree(element=XML(xml))
|
|
||||||
|
|
||||||
def get_verses(self):
|
|
||||||
#return a list of verse's and attributes
|
|
||||||
iter=self.song_xml.getiterator()
|
|
||||||
verse_list = []
|
|
||||||
for element in iter:
|
|
||||||
if element.tag == u'verse':
|
|
||||||
verse_list.append([element.attrib, element.text])
|
|
||||||
return verse_list
|
|
||||||
|
|
||||||
def dump_xml(self):
|
|
||||||
# Debugging aid to see what we have
|
|
||||||
print dump(self.song_xml)
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
sxml=SongXMLBuilder()
|
|
||||||
sxml.new_document()
|
|
||||||
sxml.add_lyrics_to_song()
|
|
||||||
sxml.add_verse_to_lyrics(u'chorus', u'1', u'The is\n is \nsome\n text')
|
|
||||||
sxml.add_verse_to_lyrics(u'verse', u'2', u'The is\n is \nmore\n text')
|
|
||||||
sxml.dump_xml()
|
|
||||||
x1 = sxml.extract_xml()
|
|
||||||
print x1
|
|
||||||
print "================================"
|
|
||||||
spra=SongXMLParser(x1)
|
|
||||||
vl = spra.get_verses()
|
|
||||||
print vl
|
|
Loading…
Reference in New Issue
Block a user