TreeViewRef

Struct TreeViewRef 

Source
pub struct TreeViewRef<'a, 'b, T> { /* private fields */ }
Expand description

Tree view widget that borrows nodes instead of owning them.

This is useful when you want to avoid cloning the tree on every render frame. Unlike TreeView which takes ownership of nodes, TreeViewRef borrows them, allowing the original data to remain in place after rendering.

§Type Parameters

  • 'a - Lifetime for borrowed UI elements.
  • 'b - Lifetime for borrowed tree nodes.
  • T - The type of data stored in tree nodes.

§Example

use ratatui_toolkit::tree_view::{TreeNode, TreeViewRef};

let nodes = vec![TreeNode::new("Root")];
let tree = TreeViewRef::new(&nodes)
    .render_fn(|data, state| {
        ratatui::text::Line::from(*data)
    });

Implementations§

Source§

impl<'a, 'b, T> TreeViewRef<'a, 'b, T>

Source

pub fn new(nodes: &'b [TreeNode<T>]) -> Self

Creates a new tree view with a reference to nodes (avoids cloning).

§Arguments
  • nodes - A reference to the root nodes of the tree.
§Returns

A new TreeViewRef with default settings.

§Example
use ratatui_toolkit::tree_view::{TreeNode, TreeViewRef};

let nodes = vec![TreeNode::new("Item")];
let tree = TreeViewRef::new(&nodes);
Source§

impl<'a, 'b, T> TreeViewRef<'a, 'b, T>

Source

pub fn block(self, block: Block<'a>) -> Self

Sets the block to wrap the tree.

§Arguments
  • block - The block to wrap the tree view.
§Returns

Self for method chaining.

§Example
use ratatui::widgets::{Block, Borders};
use ratatui_toolkit::tree_view::{TreeNode, TreeViewRef};

let nodes = vec![TreeNode::new("Item")];
let tree = TreeViewRef::new(&nodes)
    .block(Block::default().borders(Borders::ALL).title("Tree"));
Source§

impl<'a, 'b, T> TreeViewRef<'a, 'b, T>

Source

pub fn filter_fn<F>(self, _f: F) -> Self
where F: Fn(&T, &Option<String>) -> bool + 'a,

Sets a filter function for filtering nodes based on the filter text.

The function receives the node data and the current filter text, and returns true if the node should be visible.

Note: This method is currently a no-op for API compatibility. Filtering is typically handled externally via get_visible_paths_filtered.

§Arguments
  • f - A function that takes node data and filter, returns true if matches.
§Returns

Self for method chaining.

§Example
use ratatui_toolkit::tree_view::{TreeNode, TreeViewRef, helpers::matches_filter};

let nodes = vec![TreeNode::new("Item")];
let tree = TreeViewRef::new(&nodes)
    .filter_fn(|data, filter| matches_filter(data, filter));
Source§

impl<'a, 'b, T> TreeViewRef<'a, 'b, T>

Source

pub fn highlight_style(self, style: Style) -> Self

Sets the highlight style for selected rows (full-width background).

§Arguments
  • style - The style to apply to selected rows.
§Returns

Self for method chaining.

§Example
use ratatui::style::{Color, Style};
use ratatui_toolkit::tree_view::{TreeNode, TreeViewRef};

let nodes = vec![TreeNode::new("Item")];
let tree = TreeViewRef::new(&nodes)
    .highlight_style(Style::default().bg(Color::Blue));
Source§

impl<'a, 'b, T> TreeViewRef<'a, 'b, T>

Source

pub fn icon_style(self, style: Style) -> Self

Sets the style for expand/collapse icons.

§Arguments
  • style - The style to apply to icons.
§Returns

Self for method chaining.

§Example
use ratatui::style::{Color, Style};
use ratatui_toolkit::tree_view::{TreeNode, TreeViewRef};

let nodes = vec![TreeNode::new("Item")];
let tree = TreeViewRef::new(&nodes)
    .icon_style(Style::default().fg(Color::Yellow));
Source§

impl<'a, 'b, T> TreeViewRef<'a, 'b, T>

Source

pub fn icons(self, expand: &'a str, collapse: &'a str) -> Self

Sets custom expand/collapse icons.

§Arguments
  • expand - The icon to show for collapsed nodes.
  • collapse - The icon to show for expanded nodes.
§Returns

Self for method chaining.

§Example
use ratatui_toolkit::tree_view::{TreeNode, TreeViewRef};

let nodes = vec![TreeNode::new("Item")];
let tree = TreeViewRef::new(&nodes)
    .icons("+", "-");
Source§

impl<'a, 'b, T> TreeViewRef<'a, 'b, T>

Source

pub fn render_fn<F>(self, f: F) -> Self
where F: Fn(&T, &NodeState) -> Line<'a> + 'a,

Sets the render function for nodes.

§Arguments
  • f - A function that takes node data and state, returns a Line.
§Returns

Self for method chaining.

§Example
use ratatui::text::Line;
use ratatui_toolkit::tree_view::{TreeNode, TreeViewRef};

let nodes = vec![TreeNode::new("Item")];
let tree = TreeViewRef::new(&nodes)
    .render_fn(|data, state| {
        if state.is_selected {
            Line::from(format!("> {}", data))
        } else {
            Line::from(*data)
        }
    });

Trait Implementations§

Source§

impl<'a, 'b, T> StatefulWidget for TreeViewRef<'a, 'b, T>

Source§

type State = TreeViewState

State associated with the stateful widget. Read more
Source§

fn render(self, area: Rect, buf: &mut Buffer, state: &mut Self::State)

Draws the current state of the widget in the given buffer. That is the only method required to implement a custom stateful widget.

Auto Trait Implementations§

§

impl<'a, 'b, T> Freeze for TreeViewRef<'a, 'b, T>

§

impl<'a, 'b, T> !RefUnwindSafe for TreeViewRef<'a, 'b, T>

§

impl<'a, 'b, T> !Send for TreeViewRef<'a, 'b, T>

§

impl<'a, 'b, T> !Sync for TreeViewRef<'a, 'b, T>

§

impl<'a, 'b, T> Unpin for TreeViewRef<'a, 'b, T>

§

impl<'a, 'b, T> !UnwindSafe for TreeViewRef<'a, 'b, T>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more