From 55477e3ad57a01dd292ccaa2cfac30368377b39e Mon Sep 17 00:00:00 2001 From: Brage Fuglseth Date: Sun, 9 Jun 2024 21:56:02 +0200 Subject: [PATCH] text view: Proper OSK support (#15) --- src/widgets/text_view/input.rs | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/src/widgets/text_view/input.rs b/src/widgets/text_view/input.rs index 76ecb8f..23b736d 100644 --- a/src/widgets/text_view/input.rs +++ b/src/widgets/text_view/input.rs @@ -20,6 +20,26 @@ impl imp::KpTextView { } })); + input_context.connect_retrieve_surrounding(glib::clone!(@weak obj => @default-return false, move |ctx| { + let current_typed = obj.typed_text(); + let typed_len = current_typed.len() as i32; + ctx.set_surrounding_with_selection(¤t_typed, typed_len, typed_len); + true + })); + + input_context.connect_delete_surrounding(glib::clone!(@weak obj => @default-return false, move |_, offset, _| { + let mut current_typed = obj.typed_text(); + + // The cursor will always be at the end of the typed text, + // so we can safely just pop the {offset} last characters + for _ in 0..offset.abs() { + current_typed = pop_grapheme(¤t_typed); + } + + obj.set_typed_text(current_typed); + true + })); + obj.connect_has_focus_notify(glib::clone!(@weak input_context => move |obj| { if obj.has_focus() { input_context.focus_in(); @@ -28,6 +48,14 @@ impl imp::KpTextView { } })); + input_context.set_input_hints(gtk::InputHints::NO_SPELLCHECK); + + let click_gesture = gtk::GestureClick::new(); + click_gesture.connect_released(glib::clone!(@weak input_context => move |controller, _, _, _| { + input_context.activate_osk(controller.current_event()); + })); + self.obj().add_controller(click_gesture); + let event_controller = gtk::EventControllerKey::new(); event_controller.set_im_context(Some(&input_context));