diff options
Diffstat (limited to 'app-office/kmymoney/files')
-rw-r--r-- | app-office/kmymoney/files/kmymoney-4.5-accentfix.patch | 133 |
1 files changed, 133 insertions, 0 deletions
diff --git a/app-office/kmymoney/files/kmymoney-4.5-accentfix.patch b/app-office/kmymoney/files/kmymoney-4.5-accentfix.patch new file mode 100644 index 000000000000..643addcd9f38 --- /dev/null +++ b/app-office/kmymoney/files/kmymoney-4.5-accentfix.patch @@ -0,0 +1,133 @@ +Index: kmymoney/widgets/kmymoneycompletion.cpp +=================================================================== +--- kmymoney/widgets/kmymoneycompletion.cpp (Revision 1193385) ++++ kmymoney/widgets/kmymoneycompletion.cpp (Revision 1193386) +@@ -31,6 +31,8 @@ + #include <QEvent> + #include <QDesktopWidget> + #include <QLineEdit> ++#include <QInputContext> ++#include <QInputContextFactory> + + // ---------------------------------------------------------------------------- + // KDE Includes +@@ -47,13 +49,14 @@ + kMyMoneyCompletion::kMyMoneyCompletion(QWidget *parent) : + KVBox(parent) + { +- setWindowFlags(Qt::Popup); +- setFrameStyle(QFrame::StyledPanel | QFrame::Raised); ++ setWindowFlags(Qt::ToolTip); ++ // make it look like the Qt completer ++ setMargin(0); ++ setLineWidth(0); + + m_parent = parent; +- setFocusProxy(parent); +- + m_selector = new KMyMoneySelector(this); ++ m_selector->listView()->setFocusProxy(parent); + + // to handle the keyboard events received by this widget in the same way as + // the keyboard events received by the other widgets +@@ -130,9 +133,10 @@ + } + } + +-void kMyMoneyCompletion::showEvent(QShowEvent*) ++void kMyMoneyCompletion::showEvent(QShowEvent* e) + { + show(true); ++ KVBox::showEvent(e); + } + + void kMyMoneyCompletion::show(bool presetSelected) +@@ -152,8 +156,12 @@ + c->lineEdit()->installEventFilter(this); + } + } +- + KVBox::show(); ++ // after the popup is shown for the first time the input context of the combobox gets messed up ++ // so replace it whit a new input context of the same type to handle input methods correctly ++ if (m_parent) { ++ m_parent->setInputContext(QInputContextFactory::create(m_parent->inputContext()->identifierName(), m_parent)); ++ } + } + + void kMyMoneyCompletion::hide(void) +@@ -176,6 +184,9 @@ + KMyMoneyCombo *c = dynamic_cast<KMyMoneyCombo*>(m_parent); + if (o == m_parent || (c && o == c->lineEdit()) || o == this) { + if (isVisible()) { ++ if (e->type() == QEvent::FocusOut) { ++ hide(); ++ } + if (e->type() == QEvent::KeyPress) { + QTreeWidgetItem* item = 0; + QKeyEvent* ev = static_cast<QKeyEvent*>(e); +@@ -266,9 +277,6 @@ + } + } + } +- // forward any keyboard event that was received by this widget and was not handled to the parent widget +- if (o == this && c && (e->type() == QEvent::KeyPress || e->type() == QEvent::KeyRelease)) +- c->event(e); + return KVBox::eventFilter(o, e); + } + +Index: kmymoney/widgets/kmymoneyaccountcompletion.cpp +=================================================================== +--- kmymoney/widgets/kmymoneyaccountcompletion.cpp (Revision 1193385) ++++ kmymoney/widgets/kmymoneyaccountcompletion.cpp (Revision 1193386) +@@ -43,7 +43,7 @@ + { + delete m_selector; + m_selector = new kMyMoneyAccountSelector(this, 0, false); +- m_selector->listView()->setFocusProxy(this); ++ m_selector->listView()->setFocusProxy(parent); + + #ifndef KMM_DESIGNER + // Default is to show all accounts +Index: kmymoney/widgets/kmymoneyselector.cpp +=================================================================== +--- kmymoney/widgets/kmymoneyselector.cpp (Revision 1193385) ++++ kmymoney/widgets/kmymoneyselector.cpp (Revision 1193386) +@@ -43,6 +43,8 @@ + KMyMoneySelector::KMyMoneySelector(QWidget *parent, Qt::WFlags flags) : + QWidget(parent, flags) + { ++ setAutoFillBackground(true); ++ + m_selMode = QTreeWidget::SingleSelection; + + m_treeWidget = new QTreeWidget(this); +@@ -52,11 +54,6 @@ + m_treeWidget->setSortingEnabled(false); + m_treeWidget->setAlternatingRowColors(true); + +- if (parent) { +- setFocusProxy(parent->focusProxy()); +- m_treeWidget->setFocusProxy(parent->focusProxy()); +- } +- + m_treeWidget->setAllColumnsShowFocus(true); + + m_layout = new QHBoxLayout(this); +Index: kmymoney/widgets/kmymoneycombo.cpp +=================================================================== +--- kmymoney/widgets/kmymoneycombo.cpp (Revision 1193385) ++++ kmymoney/widgets/kmymoneycombo.cpp (Revision 1193386) +@@ -224,12 +224,6 @@ + + void KMyMoneyCombo::focusOutEvent(QFocusEvent* e) + { +- // when showing m_completion we'll receive a focus out event even if the focus +- // will still remain at this widget since this widget is the completion's focus proxy +- // so ignore the focus out event caused by showin a widget of type Qt::Popup +- if (e->reason() == Qt::PopupFocusReason) +- return; +- + if (m_inFocusOutEvent) { + KComboBox::focusOutEvent(e); + return; |