When emitting the roleEditingCanceled-signal it must be prevented
that a roleEditingFinished-signal is emitted because of some
action taken in the receiver-slot.
BUG: 301480
FIXED-IN: 4.9.0
}
void KStandardItemListWidget::slotRoleEditingCanceled(int index,
}
void KStandardItemListWidget::slotRoleEditingCanceled(int index,
- const QByteArray& role,
- const QVariant& value)
+ const QByteArray& role,
+ const QVariant& value)
{
closeRoleEditor();
emit roleEditingCanceled(index, role, value);
{
closeRoleEditor();
emit roleEditingCanceled(index, role, value);
}
void KStandardItemListWidget::slotRoleEditingFinished(int index,
}
void KStandardItemListWidget::slotRoleEditingFinished(int index,
- const QByteArray& role,
- const QVariant& value)
+ const QByteArray& role,
+ const QVariant& value)
{
closeRoleEditor();
emit roleEditingFinished(index, role, value);
{
closeRoleEditor();
emit roleEditingFinished(index, role, value);
KItemListRoleEditor::KItemListRoleEditor(QWidget *parent) :
KTextEdit(parent),
m_index(0),
KItemListRoleEditor::KItemListRoleEditor(QWidget *parent) :
KTextEdit(parent),
m_index(0),
+ m_role(),
+ m_blockFinishedSignal(false)
{
setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
{
setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
bool KItemListRoleEditor::eventFilter(QObject* watched, QEvent* event)
{
if (watched == parentWidget() && event->type() == QEvent::Resize) {
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);
}
return KTextEdit::eventFilter(watched, event);
if (event->type() == QEvent::FocusOut) {
QFocusEvent* focusEvent = static_cast<QFocusEvent*>(event);
if (focusEvent->reason() != Qt::PopupFocusReason) {
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);
}
}
return KTextEdit::event(event);
{
switch (event->key()) {
case Qt::Key_Escape:
{
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());
emit roleEditingCanceled(m_index, m_role, toPlainText());
+ m_blockFinishedSignal = false;
event->accept();
return;
case Qt::Key_Enter:
case Qt::Key_Return:
event->accept();
return;
case Qt::Key_Enter:
case Qt::Key_Return:
- emit roleEditingFinished(m_index, m_role, toPlainText());
+ emitRoleEditingFinished();
event->accept();
return;
default:
event->accept();
return;
default:
+void KItemListRoleEditor::emitRoleEditingFinished()
+{
+ if (!m_blockFinishedSignal) {
+ emit roleEditingFinished(m_index, m_role, toPlainText());
+ }
+}
+
#include "kitemlistroleeditor.moc"
#include "kitemlistroleeditor.moc"
*/
void autoAdjustSize();
*/
void autoAdjustSize();
+private:
+ /**
+ * Emits the signal roleEditingFinished if m_blockFinishedSignal
+ * is false.
+ */
+ void emitRoleEditingFinished();
+
private:
int m_index;
QByteArray m_role;
private:
int m_index;
QByteArray m_role;
+ bool m_blockFinishedSignal;