}
void KStandardItemListWidget::slotRoleEditingCanceled(int index,
- const QByteArray& role,
- const QVariant& value)
+ const QByteArray& role,
+ const QVariant& value)
{
closeRoleEditor();
emit roleEditingCanceled(index, role, value);
}
void KStandardItemListWidget::slotRoleEditingFinished(int index,
- const QByteArray& role,
- const QVariant& value)
+ const QByteArray& role,
+ const QVariant& value)
{
closeRoleEditor();
emit roleEditingFinished(index, role, value);
KItemListRoleEditor::KItemListRoleEditor(QWidget *parent) :
KTextEdit(parent),
m_index(0),
- m_role()
+ m_role(),
+ m_blockFinishedSignal(false)
{
setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
bool KItemListRoleEditor::eventFilter(QObject* watched, QEvent* event)
{
if (watched == parentWidget() && event->type() == QEvent::Resize) {
- emit roleEditingFinished(m_index, m_role, toPlainText());
+ emitRoleEditingFinished();
}
return KTextEdit::eventFilter(watched, event);
if (event->type() == QEvent::FocusOut) {
QFocusEvent* focusEvent = static_cast<QFocusEvent*>(event);
if (focusEvent->reason() != Qt::PopupFocusReason) {
- emit roleEditingFinished(m_index, m_role, toPlainText());
+ emitRoleEditingFinished();
}
}
return KTextEdit::event(event);
{
switch (event->key()) {
case Qt::Key_Escape:
+ // Emitting the signal roleEditingCanceled might result
+ // in losing the focus. Per default losing the focus emits
+ // a roleEditingFinished signal (see KItemListRoleEditor::event),
+ // which is not wanted in this case.
+ m_blockFinishedSignal = true;
emit roleEditingCanceled(m_index, m_role, toPlainText());
+ m_blockFinishedSignal = false;
event->accept();
return;
case Qt::Key_Enter:
case Qt::Key_Return:
- emit roleEditingFinished(m_index, m_role, toPlainText());
+ emitRoleEditingFinished();
event->accept();
return;
default:
}
}
+void KItemListRoleEditor::emitRoleEditingFinished()
+{
+ if (!m_blockFinishedSignal) {
+ emit roleEditingFinished(m_index, m_role, toPlainText());
+ }
+}
+
#include "kitemlistroleeditor.moc"