mirror of https://github.com/procxx/kepka.git
Fixed dead keys in photo / file caption input field #1418
Another attempt to fix dead keys input problem after main window looses focus to popup menu or photo viewer #2007 #1074
This commit is contained in:
parent
12c20faa44
commit
f6af535f8f
|
@ -926,13 +926,26 @@ void MainWindow::layerHidden() {
|
|||
setInnerFocus();
|
||||
}
|
||||
|
||||
void MainWindow::onReActivate() {
|
||||
if (auto w = App::wnd()) {
|
||||
if (auto f = QApplication::focusWidget()) {
|
||||
f->clearFocus();
|
||||
}
|
||||
w->windowHandle()->requestActivate();
|
||||
w->activate();
|
||||
if (auto f = QApplication::focusWidget()) {
|
||||
f->clearFocus();
|
||||
}
|
||||
w->setInnerFocus();
|
||||
}
|
||||
}
|
||||
|
||||
void MainWindow::hideMediaview() {
|
||||
if (_mediaView && !_mediaView->isHidden()) {
|
||||
_mediaView->hide();
|
||||
#if defined Q_OS_LINUX32 || defined Q_OS_LINUX64
|
||||
if (App::wnd()) {
|
||||
App::wnd()->activateWindow();
|
||||
}
|
||||
onReActivate();
|
||||
QTimer::singleShot(200, this, SLOT(onReActivate()));
|
||||
#endif
|
||||
}
|
||||
}
|
||||
|
|
|
@ -282,6 +282,8 @@ public slots:
|
|||
void onLogoutSure();
|
||||
void updateGlobalMenu(); // for OS X top menu
|
||||
|
||||
void onReActivate();
|
||||
|
||||
void notifyUpdateAllPhotos();
|
||||
|
||||
void app_activateClickHandler(ClickHandlerPtr handler, Qt::MouseButton button);
|
||||
|
|
|
@ -765,11 +765,11 @@ void InputArea::startBorderAnimation() {
|
|||
}
|
||||
|
||||
void InputArea::focusInEvent(QFocusEvent *e) {
|
||||
_inner.setFocus();
|
||||
QTimer::singleShot(0, &_inner, SLOT(setFocus()));
|
||||
}
|
||||
|
||||
void InputArea::mousePressEvent(QMouseEvent *e) {
|
||||
_inner.setFocus();
|
||||
QTimer::singleShot(0, &_inner, SLOT(setFocus()));
|
||||
}
|
||||
|
||||
void InputArea::contextMenuEvent(QContextMenuEvent *e) {
|
||||
|
@ -1457,11 +1457,11 @@ void InputField::startBorderAnimation() {
|
|||
}
|
||||
|
||||
void InputField::focusInEvent(QFocusEvent *e) {
|
||||
_inner.setFocus();
|
||||
QTimer::singleShot(0, &_inner, SLOT(setFocus()));
|
||||
}
|
||||
|
||||
void InputField::mousePressEvent(QMouseEvent *e) {
|
||||
_inner.setFocus();
|
||||
QTimer::singleShot(0, &_inner, SLOT(setFocus()));
|
||||
}
|
||||
|
||||
void InputField::contextMenuEvent(QContextMenuEvent *e) {
|
||||
|
|
|
@ -235,6 +235,12 @@ public:
|
|||
bool hasFocus() const {
|
||||
return _inner.hasFocus();
|
||||
}
|
||||
void setFocus() {
|
||||
_inner.setFocus();
|
||||
}
|
||||
void clearFocus() {
|
||||
_inner.clearFocus();
|
||||
}
|
||||
|
||||
public slots:
|
||||
|
||||
|
|
|
@ -521,8 +521,9 @@ PopupMenu::~PopupMenu() {
|
|||
clearActions(true);
|
||||
delete _menu;
|
||||
#if defined Q_OS_LINUX32 || defined Q_OS_LINUX64
|
||||
if (App::wnd()) {
|
||||
App::wnd()->activateWindow();
|
||||
if (auto w = App::wnd()) {
|
||||
w->onReActivate();
|
||||
QTimer::singleShot(200, w, SLOT(onReActivate()));
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue