#cursor-position #ratatui #cursor #input

rat-cursor

ratatui trait to communicate the cursor position across widgets

7 releases (4 stable)

new 1.2.0 Jan 5, 2025
1.1.1 Jan 3, 2025
1.0.0 Dec 29, 2024
0.25.1 Oct 18, 2024
0.1.0 Sep 12, 2024

#941 in Command-line interface

Download history 34/week @ 2024-09-15 10/week @ 2024-09-22 13/week @ 2024-09-29 175/week @ 2024-10-06 227/week @ 2024-10-13 49/week @ 2024-10-20 29/week @ 2024-10-27 16/week @ 2024-11-03 5/week @ 2024-11-10 88/week @ 2024-11-17 241/week @ 2024-11-24 106/week @ 2024-12-01 215/week @ 2024-12-08 208/week @ 2024-12-15 97/week @ 2024-12-22 420/week @ 2024-12-29

950 downloads per month
Used in 9 crates (4 directly)

MIT/Apache

6KB

semver stable crates.io Documentation License License

This crate is a part of rat-salsa.

Rat-Cursor

Why?

This crate defines just the trait HasScreenCursor for use in other crates. This aims to overcome the shortcomings of ratatui to handle cursor positioning by widgets.

In the long run I hope there will be a solution within ratatui which will make this obsolete, but for now ...

pub trait HasScreenCursor {
    fn screen_cursor(&self) -> Option<(u16, u16)>;
}

Use

Widget

This trait is implemented for the widget-state struct.

It's implemented for the state struct because the widget might need to run the full layout process to know the cursor position. Which would approximately double the rendering process.

Instead of setting the cursor position during rendering somehow, the rendering process stores the cursor position in the state struct, where it can be retrieved later on.

The trait returns a screen-position, but only if it actually needs the cursor to be displayed:

  • The cursor is not scrolled off-screen.
  • The widget has some kind of input-focus.

Container widget

A container widget can cascade down to its components.

    fn screen_cursor(&self) -> Option<(u16, u16)> {
    self.widget1.screen_cursor()
        .or(self.widget2.screen_cursor())
        .or(self.widget3.screen_cursor())
}

No runtime deps