forked from openlp/openlp
fix up edit code
This commit is contained in:
parent
676b9133d1
commit
eb1703bcc9
@ -42,6 +42,16 @@ from openlp.core.lib.ui import critical_error_message_box
|
|||||||
from openlp.core.ui.formattingtagdialog import Ui_FormattingTagDialog
|
from openlp.core.ui.formattingtagdialog import Ui_FormattingTagDialog
|
||||||
|
|
||||||
|
|
||||||
|
class EDITCOLUMN(object):
|
||||||
|
"""
|
||||||
|
Hides the magic numbers for the table columns
|
||||||
|
"""
|
||||||
|
Description = 0
|
||||||
|
Tag = 1
|
||||||
|
StartHtml = 2
|
||||||
|
EndHtml = 3
|
||||||
|
|
||||||
|
|
||||||
class FormattingTagForm(QtGui.QDialog, Ui_FormattingTagDialog):
|
class FormattingTagForm(QtGui.QDialog, Ui_FormattingTagDialog):
|
||||||
"""
|
"""
|
||||||
The :class:`FormattingTagForm` manages the settings tab .
|
The :class:`FormattingTagForm` manages the settings tab .
|
||||||
@ -58,7 +68,7 @@ class FormattingTagForm(QtGui.QDialog, Ui_FormattingTagDialog):
|
|||||||
r'|(?P<procinst>\?(?:(?!\?>).)*\?)'
|
r'|(?P<procinst>\?(?:(?!\?>).)*\?)'
|
||||||
r'|(?P<comment>!--(?:(?!-->).)*--))>', re.UNICODE)
|
r'|(?P<comment>!--(?:(?!-->).)*--))>', re.UNICODE)
|
||||||
self.html_regex = re.compile(r'^(?:[^<>]*%s)*[^<>]*$' % self.html_tag_regex.pattern)
|
self.html_regex = re.compile(r'^(?:[^<>]*%s)*[^<>]*$' % self.html_tag_regex.pattern)
|
||||||
#self.tag_table_widget.itemSelectionChanged.connect(self.on_row_selected)
|
self.tag_table_widget.itemSelectionChanged.connect(self.on_row_selected)
|
||||||
self.new_button.clicked.connect(self.on_new_clicked)
|
self.new_button.clicked.connect(self.on_new_clicked)
|
||||||
#self.save_push_button.clicked.connect(self.on_saved_clicked)
|
#self.save_push_button.clicked.connect(self.on_saved_clicked)
|
||||||
self.delete_button.clicked.connect(self.on_delete_clicked)
|
self.delete_button.clicked.connect(self.on_delete_clicked)
|
||||||
@ -66,7 +76,6 @@ class FormattingTagForm(QtGui.QDialog, Ui_FormattingTagDialog):
|
|||||||
self.button_box.rejected.connect(self.close)
|
self.button_box.rejected.connect(self.close)
|
||||||
# Forces reloading of tags from openlp configuration.
|
# Forces reloading of tags from openlp configuration.
|
||||||
FormattingTags.load_tags()
|
FormattingTags.load_tags()
|
||||||
self.pause_validation = False
|
|
||||||
|
|
||||||
def exec_(self):
|
def exec_(self):
|
||||||
"""
|
"""
|
||||||
@ -80,76 +89,33 @@ class FormattingTagForm(QtGui.QDialog, Ui_FormattingTagDialog):
|
|||||||
"""
|
"""
|
||||||
Table Row selected so display items and set field state.
|
Table Row selected so display items and set field state.
|
||||||
"""
|
"""
|
||||||
#self.save_push_button.setEnabled(False)
|
self.delete_button.setEnabled(True)
|
||||||
self.selected = self.tag_table_widget.currentRow()
|
|
||||||
html = FormattingTags.get_html_tags()[self.selected]
|
|
||||||
self.description_line_edit.setText(html[u'desc'])
|
|
||||||
self.tag_line_edit.setText(self._strip(html[u'start tag']))
|
|
||||||
self.start_tag_line_edit.setText(html[u'start html'])
|
|
||||||
self.end_tag_line_edit.setText(html[u'end html'])
|
|
||||||
if html[u'protected']:
|
|
||||||
self.description_line_edit.setEnabled(False)
|
|
||||||
self.tag_line_edit.setEnabled(False)
|
|
||||||
self.start_tag_line_edit.setEnabled(False)
|
|
||||||
self.end_tag_line_edit.setEnabled(False)
|
|
||||||
self.delete_push_button.setEnabled(False)
|
|
||||||
else:
|
|
||||||
self.description_line_edit.setEnabled(True)
|
|
||||||
self.tag_line_edit.setEnabled(True)
|
|
||||||
self.start_tag_line_edit.setEnabled(True)
|
|
||||||
self.end_tag_line_edit.setEnabled(True)
|
|
||||||
self.delete_push_button.setEnabled(True)
|
|
||||||
|
|
||||||
def on_text_edited(self, text):
|
|
||||||
"""
|
|
||||||
Enable the ``save_push_button`` when any of the selected tag's properties
|
|
||||||
has been changed.
|
|
||||||
"""
|
|
||||||
self.save_push_button.setEnabled(True)
|
|
||||||
|
|
||||||
def on_new_clicked(self):
|
def on_new_clicked(self):
|
||||||
"""
|
"""
|
||||||
Add a new tag to list only if it is not a duplicate.
|
Add a new tag to edit list and select it for editing.
|
||||||
"""
|
"""
|
||||||
last_row = self.tag_table_widget.rowCount() - 1
|
new_row = self.tag_table_widget.rowCount()
|
||||||
self.tag_table_widget.selectRow(last_row)
|
self.tag_table_widget.insertRow(new_row)
|
||||||
self.tag_table_widget.setCurrentCell(last_row, 0)
|
self.tag_table_widget.setItem(new_row, 0,
|
||||||
for html in FormattingTags.get_html_tags():
|
QtGui.QTableWidgetItem(translate('OpenLP.FormattingTagForm', 'New Tag')))
|
||||||
if self._strip(html[u'start tag']) == u'n':
|
self.tag_table_widget.setItem(new_row, 1,
|
||||||
critical_error_message_box(
|
QtGui.QTableWidgetItem('n%s' % unicode(new_row)))
|
||||||
translate('OpenLP.FormattingTagForm', 'Update Error'),
|
self.tag_table_widget.setItem(new_row, 2,
|
||||||
translate('OpenLP.FormattingTagForm', 'Tag "n" already defined.'))
|
QtGui.QTableWidgetItem(translate('OpenLP.FormattingTagForm', '<HTML here>')))
|
||||||
return
|
self.tag_table_widget.setItem(new_row, 3,
|
||||||
# Add new tag to list
|
QtGui.QTableWidgetItem(translate('OpenLP.FormattingTagForm', '</and here>')))
|
||||||
tag = {
|
self.tag_table_widget.resizeRowsToContents()
|
||||||
u'desc': translate('OpenLP.FormattingTagForm', 'New Tag'),
|
|
||||||
u'start tag': u'{n%s}' % unicode(last_row + 1),
|
|
||||||
u'start html': translate('OpenLP.FormattingTagForm', '<HTML here>'),
|
|
||||||
u'end tag': u'{/n%s}' % unicode(last_row + 1),
|
|
||||||
u'end html': translate('OpenLP.FormattingTagForm', '</and here>'),
|
|
||||||
u'protected': False,
|
|
||||||
u'temporary': False
|
|
||||||
}
|
|
||||||
#FormattingTags.add_html_tags([tag])
|
|
||||||
#FormattingTags.save_html_tags()
|
|
||||||
#self._reloadTable()
|
|
||||||
# Highlight new row
|
|
||||||
#self.tag_table_widget.selectRow(self.tag_table_widget.rowCount() - 1)
|
|
||||||
#self.on_row_selected()
|
|
||||||
self.tag_table_widget.scrollToBottom()
|
self.tag_table_widget.scrollToBottom()
|
||||||
|
self.tag_table_widget.selectRow(new_row)
|
||||||
|
|
||||||
def on_delete_clicked(self):
|
def on_delete_clicked(self):
|
||||||
"""
|
"""
|
||||||
Delete selected custom tag.
|
Delete selected custom row.
|
||||||
"""
|
"""
|
||||||
if self.selected != -1:
|
selected = self.tag_table_widget.currentRow()
|
||||||
FormattingTags.remove_html_tag(self.selected)
|
if selected != -1:
|
||||||
# As the first items are protected we should not have to take care
|
self.tag_table_widget.removeRow(selected)
|
||||||
# of negative indexes causing tracebacks.
|
|
||||||
self.tag_table_widget.selectRow(self.selected - 1)
|
|
||||||
self.selected = -1
|
|
||||||
FormattingTags.save_html_tags()
|
|
||||||
self._reloadTable()
|
|
||||||
|
|
||||||
def on_saved_clicked(self):
|
def on_saved_clicked(self):
|
||||||
"""
|
"""
|
||||||
@ -217,12 +183,10 @@ class FormattingTagForm(QtGui.QDialog, Ui_FormattingTagDialog):
|
|||||||
# only process for editable rows
|
# only process for editable rows
|
||||||
pre_row_item = self.tag_table_widget.item(pre_row, 0)
|
pre_row_item = self.tag_table_widget.item(pre_row, 0)
|
||||||
edit_item = None
|
edit_item = None
|
||||||
if pre_row_item and (pre_row_item.flags() & QtCore.Qt.ItemIsEditable) and not self.pause_validation:
|
if pre_row_item and (pre_row_item.flags() & QtCore.Qt.ItemIsEditable):
|
||||||
data = self.item_to_data_dict(pre_row_item)
|
|
||||||
item = self.tag_table_widget.item(pre_row, pre_col)
|
item = self.tag_table_widget.item(pre_row, pre_col)
|
||||||
text = unicode(item.text())
|
text = unicode(item.text())
|
||||||
if pre_col is 0:
|
if pre_col is EDITCOLUMN.Tag:
|
||||||
# Tag name edited
|
|
||||||
if text:
|
if text:
|
||||||
for row in range(self.tag_table_widget.rowCount()):
|
for row in range(self.tag_table_widget.rowCount()):
|
||||||
counting_item = self.tag_table_widget.item(row, 0)
|
counting_item = self.tag_table_widget.item(row, 0)
|
||||||
@ -233,33 +197,10 @@ class FormattingTagForm(QtGui.QDialog, Ui_FormattingTagDialog):
|
|||||||
'Tag %s is already defined. Please pick a different one.' % text),
|
'Tag %s is already defined. Please pick a different one.' % text),
|
||||||
QtGui.QMessageBox.Discard|QtGui.QMessageBox.Ok)
|
QtGui.QMessageBox.Discard|QtGui.QMessageBox.Ok)
|
||||||
if answer == QtGui.QMessageBox.Discard:
|
if answer == QtGui.QMessageBox.Discard:
|
||||||
item.setText(data.get(u'tag'))
|
break
|
||||||
else:
|
else:
|
||||||
edit_item = item
|
edit_item = item
|
||||||
break
|
break
|
||||||
if not edit_item:
|
|
||||||
data[u'tag'] = text
|
|
||||||
data.setdefault(u'description', u'')
|
|
||||||
data.setdefault(u'html', u'')
|
|
||||||
pre_row_item.setData(QtCore.Qt.UserRole, data)
|
|
||||||
flags = self.tag_table_widget.item(pre_row, 1).flags()
|
|
||||||
if not (flags & QtCore.Qt.ItemIsEditable):
|
|
||||||
# if description cell is read only, the user is adding a new tag.
|
|
||||||
# So we add another empty row and enable editing for description and html.
|
|
||||||
new_row = self.tag_table_widget.rowCount()
|
|
||||||
self.tag_table_widget.insertRow(new_row)
|
|
||||||
for column in range(4):
|
|
||||||
new_item = QtGui.QTableWidgetItem(u'')
|
|
||||||
if column != 0:
|
|
||||||
new_item.setFlags(flags)
|
|
||||||
self.tag_table_widget.setItem(new_row, column, new_item)
|
|
||||||
for column in [1, 2]:
|
|
||||||
self.tag_table_widget.item(pre_row, column).setFlags(item.flags())
|
|
||||||
# trigger edit as editing might have been enabled after selecting
|
|
||||||
if cur_row == pre_row and cur_col in [1, 2]:
|
|
||||||
cur_item = self.tag_table_widget.item(cur_row, cur_col)
|
|
||||||
self.tag_table_widget.editItem(cur_item)
|
|
||||||
self.tag_table_widget.resizeRowsToContents()
|
|
||||||
else:
|
else:
|
||||||
answer = None
|
answer = None
|
||||||
if self.tag_table_widget.item(pre_row, 1).text() or self.tag_table_widget.item(pre_row, 2).text():
|
if self.tag_table_widget.item(pre_row, 1).text() or self.tag_table_widget.item(pre_row, 2).text():
|
||||||
@ -268,43 +209,32 @@ class FormattingTagForm(QtGui.QDialog, Ui_FormattingTagDialog):
|
|||||||
translate('OpenLP.FormattingTagForm',
|
translate('OpenLP.FormattingTagForm',
|
||||||
'No tag name defined. Do you want to delete the whole tag?'),
|
'No tag name defined. Do you want to delete the whole tag?'),
|
||||||
QtGui.QMessageBox.Yes|QtGui.QMessageBox.Discard|QtGui.QMessageBox.Cancel)
|
QtGui.QMessageBox.Yes|QtGui.QMessageBox.Discard|QtGui.QMessageBox.Cancel)
|
||||||
if answer == QtGui.QMessageBox.Discard:
|
#if answer == QtGui.QMessageBox.Discard:
|
||||||
item.setText(data.get(u'tag'))
|
# item.setText(data.get(u'tag'))
|
||||||
if answer == QtGui.QMessageBox.Cancel:
|
#if answer == QtGui.QMessageBox.Cancel:
|
||||||
edit_item = item
|
# edit_item = item
|
||||||
elif pre_row < self.tag_table_widget.rowCount() - 1:
|
elif pre_row < self.tag_table_widget.rowCount() - 1:
|
||||||
self.tag_table_widget.removeRow(pre_row)
|
self.tag_table_widget.removeRow(pre_row)
|
||||||
elif pre_col is 1:
|
#elif pre_col is EDITCOLUMN.StartHtml:
|
||||||
# Description edited
|
|
||||||
data[u'description'] = text
|
|
||||||
pre_row_item.setData(QtCore.Qt.UserRole, data)
|
|
||||||
elif pre_col is 2:
|
|
||||||
# HTML edited
|
# HTML edited
|
||||||
end_html = self.start_html_to_end_html(text)
|
#end_html = self.start_html_to_end_html(text)
|
||||||
if end_html is not None:
|
#if end_html is not None:
|
||||||
item.setToolTip(cgi.escape(text))
|
# item.setToolTip(cgi.escape(text))
|
||||||
if self.tag_table_widget.item(pre_row, 3) is None:
|
## if self.tag_table_widget.item(pre_row, 3) is None:
|
||||||
self.tag_table_widget.setItem(pre_row, 3, QtGui.QTableWidgetItem(end_html))
|
# self.tag_table_widget.setItem(pre_row, 3, QtGui.QTableWidgetItem(end_html))
|
||||||
else:
|
# else:
|
||||||
self.tag_table_widget.item(pre_row, 3).setText(end_html)
|
# self.tag_table_widget.item(pre_row, 3).setText(end_html)
|
||||||
self.tag_table_widget.item(pre_row, 3).setToolTip(cgi.escape(end_html))
|
# self.tag_table_widget.item(pre_row, 3).setToolTip(cgi.escape(end_html))
|
||||||
data[u'html'] = text
|
# #data[u'html'] = text
|
||||||
pre_row_item.setData(QtCore.Qt.UserRole, data)
|
# #pre_row_item.setData(QtCore.Qt.UserRole, data)
|
||||||
self.tag_table_widget.resizeRowsToContents()
|
# # self.tag_table_widget.resizeRowsToContents()
|
||||||
elif QtGui.QMessageBox.question(self,
|
#if not edit_item:
|
||||||
translate('OpenLP.FormattingTagForm', 'Validation Error'),
|
# # select the tag cell in a empty row
|
||||||
translate('OpenLP.FormattingTagForm', 'The entered HTML is not valid. Please enter valid HTML.'),
|
# cur_row_item = self.tag_table_widget.item(cur_row, 0)
|
||||||
QtGui.QMessageBox.Ok | QtGui.QMessageBox.Cancel) == QtGui.QMessageBox.Cancel:
|
# if cur_row_item and (cur_row_item.flags() & QtCore.Qt.ItemIsEditable) and cur_row_item.text().isEmpty():
|
||||||
item.setText(data.get(u'html'))
|
# edit_item = cur_row_item
|
||||||
else:
|
#if edit_item:
|
||||||
edit_item = item
|
# self.tag_table_widget.setCurrentItem(edit_item)
|
||||||
if not edit_item:
|
|
||||||
# select the tag cell in a empty row
|
|
||||||
cur_row_item = self.tag_table_widget.item(cur_row, 0)
|
|
||||||
if cur_row_item and (cur_row_item.flags() & QtCore.Qt.ItemIsEditable) and cur_row_item.text().isEmpty():
|
|
||||||
edit_item = cur_row_item
|
|
||||||
if edit_item:
|
|
||||||
self.tag_table_widget.setCurrentItem(edit_item)
|
|
||||||
# enable delete_button for editable rows
|
# enable delete_button for editable rows
|
||||||
cur_row = self.tag_table_widget.currentRow()
|
cur_row = self.tag_table_widget.currentRow()
|
||||||
cur_row_item = self.tag_table_widget.item(cur_row, 0)
|
cur_row_item = self.tag_table_widget.item(cur_row, 0)
|
||||||
|
Loading…
Reference in New Issue
Block a user