edtui 0.8.5

A TUI based vim inspired editor
Documentation
//! ## `EdTUI`
//!
//!<div align="center">
//!     
//! [![Continuous Integration](https://github.com/preiter93/edtui/actions/workflows/ci.yml/badge.svg)](https://github.com/preiter93/edtui/actions/workflows/ci.yml)
//!
//! </div>
//!
//! ### Overview
//! `EdTUI` is a text editor widget for the [Ratatui](https://github.com/ratatui-org/ratatui) ecosystem.
//! It is designed to provide a light-weight user experience inspired by Vim.
//!
//! Instantiate the state and render the view:
//! ```ignore
//! use edtui::{EditorEventHandler, EditorState, EditorTheme, EditorView};
//! use ratatui::widgets::Widget;
//!
//! let mut state = EditorState::default();
//! EditorView::new(&mut state)
//!         .theme(EditorTheme::default())
//!         .wrap(true) // line wrapping
//!         .render(area, buf);
//!
//! ```
//!
//! Handle events:
//! ```ignore
//! let mut event_handler = EditorEventHandler::default();
//!
//! // or handle only key events
//! event_handler.on_key_event(key_event, &mut state);
//!
//! // has experimental support for mouse events
//! event_handler.on_mouse_event(mouse_event, &mut state);
//!
//! // handles both key and mouse events
//! event_handler.on_event(event, &mut state);
//! ```
//!
//! ## Features
//! - Vim-like keybindings and editing modes for efficient text manipulation.
//! - Copy paste using the systems clipboard.
//! - Line wrapping.
//! - Syntax highlighting (experimental).
//! - Mouse support (experimental).
//!
//! ## Demo
//!
//!![](resources/app.gif)
//!
//! ## Keybindings
//! `EdTUI` offers a set of keybindings similar to Vim. Here are some of the most common keybindings:
//!
//! #### Normal Mode:
//!
//! | Keybinding                | Description                                  |
//! |---------------------------|----------------------------------------------|
//! | `i`                       | Enter Insert mode                            |
//! | `v`                       | Enter Visual mode                            |
//! | `h`, `j`, `k`, `l`        | Navigate left, down, up, and right           |
//! | `w`, `b`                  | Move forward or backward by word             |
//! | `x`                       | Delete the character under the cursor        |
//! | `u`, `<ctrl>+r`           | Undo/Redo last action                        |
//! | `Esc`                     | Escape Visual mode                           |
//! | `0`                       | Move cursor to start of line                 |
//! | `^`                       | Move cursor to first non-blank character     |
//! | `$`                       | Move cursor to end of line                   |
//! | `gg`                      | Move cursor to the first row                 |
//! | `G `                      | Move cursor to the last row                  |
//! | `%`                       | Move cursor to closing/opening bracket       |
//! | `a`                       | Append after the cursor                      |
//! | `A`                       | Append at the end of the line                |
//! | `o`                       | Add a new line below and enter Insert mode   |
//! | `O`                       | Add a new line above and enter Insert mode   |
//! | `J`                       | Join current line with the line below        |
//! | `d`                       | Delete the selection (Visual mode)           |
//! | `dd`                      | Delete the current line                      |
//! | `D`                       | Delete to the end of the line                |
//! | `viw`                     | Select between delimiters. Supported: [`"`]  |
//! | `vi` + `", ', (, [ or {`  | Select between delimiter `", ', (, [ or {`   |
//! | `ci` + `", ', (, [ or {`  | Change between delimiter `", ', (, [ or {`   |
//! | `u`                       | Undo the last change                         |
//! | `r`                       | Redo the last undone action                  |
//! | `y`                       | Copy the selected text                       |
//! | `p`                       | Paste the copied text                        |
//!
//! #### Insert Mode:
//!
//! | Keybinding  | Description                             |
//! |-------------|-----------------------------------------|
//! | `Esc`       | Return to Normal mode                   |
//! | `Backspace` | Delete the previous character                |
//! | `Enter`     | Insert line break                       |
//! | `Arrows`    | Navigation                              |
//!
//! For more keybindings and customization options, refer to the code.
//!
//! ## Experimental Mouse Support
//!
//! `Edtui` includes experimental mouse support:
//! ```ignore
//! let event_handler = EditorEvent::default();
//! event_handler.on_mouse_event(mouse_event, &mut state);
//! ```
//!
//! **Note**: This feature is experimental, so expect potential bugs and breaking changes. It does
//! currently not work correctly on wrapped lines.
//!
//! ## Syntax highlighting
//!
//! Syntax highlighting was added in version `0.8.4`. It is experimental, so expect breaking changes.
//!
//! `Edtui` offers a number of custom themes, see [`SyntaxHighlighter::theme`] for a complete list.
//! If you want to use a custom theme, see [`SyntaxHighlighter::custom_theme`]. Check [syntect](https://github.com/trishume/syntect)
//! for more details about themes and extensions.
//!
//!```ignore
//! use edtui::EditorState;
//! use edtui::EditorView;
//! use edtui::SyntaxHighlighter;
//!
//! let theme_name = "dracula";
//! let extension = "rs";
//! let syntax_highlighter = SyntaxHighlighter::new(theme_name, extension);
//! EditorView::new(&mut EditorState::default())
//!         .syntax_highlighter(Some(syntax_highlighter))
//!         .render(area, buf);
//!```
//!
//!![](resources/syntax_highlighting.gif)
//!
//! ### Roadmap
//! - [ ] Support termwiz and termion
//! - [ ] Display line numbers
//! - [ ] Remap keybindings
#![allow(
    dead_code,
    clippy::module_name_repetitions,
    clippy::cast_possible_truncation
)]
pub mod actions;
pub mod clipboard;
mod debug;
pub mod events;
mod helper;
mod internal;
mod state;
#[cfg(feature = "syntax-highlighting")]
mod syntax_higlighting;
mod view;

#[allow(deprecated)]
pub use events::deprecated_input::EditorInput;
pub use events::EditorEventHandler;
pub use state::{mode::EditorMode, EditorState};
pub use view::{theme::EditorTheme, EditorStatusLine, EditorView};

#[cfg(feature = "syntax-highlighting")]
pub use syntax_higlighting::SyntaxHighlighter;

#[cfg(feature = "syntax-highlighting")]
pub use syntect;

/// A data structure that contains chars organized in rows and columns
pub type Lines = jagged::Jagged<char>;
pub use jagged::index::RowIndex;
pub use jagged::Index2;