diff options
| author | 2023-12-15 13:15:44 +0100 | |
|---|---|---|
| committer | 2023-12-15 13:39:00 +0100 | |
| commit | e819c2390bad76e811265245bd5fab63fc30a8b2 (patch) | |
| tree | e19db58cbf4cd5529bd74f1f82764103f59f2236 /widget/src/text_input | |
| parent | dd249a1d11c68b8fee1828d58bae158946ee2ebd (diff) | |
| download | iced-e819c2390bad76e811265245bd5fab63fc30a8b2.tar.gz iced-e819c2390bad76e811265245bd5fab63fc30a8b2.tar.bz2 iced-e819c2390bad76e811265245bd5fab63fc30a8b2.zip | |
Update `winit` to `0.29.4`
Diffstat (limited to '')
| -rw-r--r-- | widget/src/text_input.rs | 56 | 
1 files changed, 27 insertions, 29 deletions
| diff --git a/widget/src/text_input.rs b/widget/src/text_input.rs index 65d3e1eb..8ba4bd71 100644 --- a/widget/src/text_input.rs +++ b/widget/src/text_input.rs @@ -752,34 +752,9 @@ where                  return event::Status::Captured;              }          } -        Event::Keyboard(keyboard::Event::CharacterReceived(c)) => { -            let state = state(); - -            if let Some(focus) = &mut state.is_focused { -                let Some(on_input) = on_input else { -                    return event::Status::Ignored; -                }; - -                if state.is_pasting.is_none() -                    && !state.keyboard_modifiers.command() -                    && !c.is_control() -                { -                    let mut editor = Editor::new(value, &mut state.cursor); - -                    editor.insert(c); - -                    let message = (on_input)(editor.contents()); -                    shell.publish(message); - -                    focus.updated_at = Instant::now(); - -                    update_cache(state, value); - -                    return event::Status::Captured; -                } -            } -        } -        Event::Keyboard(keyboard::Event::KeyPressed { key_code, .. }) => { +        Event::Keyboard(keyboard::Event::KeyPressed { +            key_code, text, .. +        }) => {              let state = state();              if let Some(focus) = &mut state.is_focused { @@ -971,7 +946,30 @@ where                      | keyboard::KeyCode::Down => {                          return event::Status::Ignored;                      } -                    _ => {} +                    _ => { +                        if let Some(text) = text { +                            let c = text.chars().next().unwrap_or_default(); + +                            if state.is_pasting.is_none() +                                && !state.keyboard_modifiers.command() +                                && !c.is_control() +                            { +                                let mut editor = +                                    Editor::new(value, &mut state.cursor); + +                                editor.insert(c); + +                                let message = (on_input)(editor.contents()); +                                shell.publish(message); + +                                focus.updated_at = Instant::now(); + +                                update_cache(state, value); + +                                return event::Status::Captured; +                            } +                        } +                    }                  }                  return event::Status::Captured; | 
