From f7233786d2bd7211421c76cbfdbc269eb1c44566 Mon Sep 17 00:00:00 2001 From: smatz Date: Wed, 28 May 2008 15:28:27 +0000 Subject: (svn r13310) -Fix: invalidate OSK when parent editbox changes (from keyboard) --- src/misc_gui.cpp | 5 +++++ src/osk_gui.cpp | 5 +++++ 2 files changed, 10 insertions(+) diff --git a/src/misc_gui.cpp b/src/misc_gui.cpp index 24829904c..c28f7ee20 100644 --- a/src/misc_gui.cpp +++ b/src/misc_gui.cpp @@ -1083,6 +1083,11 @@ struct QueryStringWindow : public QueryStringBaseWindow { EventState state; switch (this->HandleEditBoxKey(QUERY_STR_WIDGET_TEXT, key, keycode, state)) { + default: NOT_REACHED(); + case 0: { + Window *osk = FindWindowById(WC_OSK, 0); + if (osk != NULL && osk->parent == this) osk->OnInvalidateData(); + } break; case 1: this->OnOk(); // Enter pressed, confirms change /* FALL THROUGH */ case 2: delete this; break; // ESC pressed, closes window, abandons changes diff --git a/src/osk_gui.cpp b/src/osk_gui.cpp index bd7bc16bd..2f1bc41ea 100644 --- a/src/osk_gui.cpp +++ b/src/osk_gui.cpp @@ -203,6 +203,11 @@ struct OskWindow : public Window { /* make the caret of the parent window also blink */ this->parent->InvalidateWidget(this->text_btn); } + + virtual void OnInvalidateData(int) + { + this->InvalidateWidget(OSK_WIDGET_TEXT); + } }; static const Widget _osk_widgets[] = { -- cgit v1.2.3-54-g00ecf