Struct cursive_core::views::ListView

source ·
pub struct ListView { /* private fields */ }
Expand description

Displays a list of elements.

Implementations§

source§

impl ListView

source

pub fn new() -> Self

Creates a new, empty ListView.

source

pub fn len(&self) -> usize

Returns the number of children, including delimiters.

source

pub fn is_empty(&self) -> bool

Returns true if this view contains no children.

Returns false if at least a delimiter or a view is present.

source

pub fn children(&self) -> &[ListChild]

Returns a reference to the children

source

pub fn get_row(&self, id: usize) -> &ListChild

Returns a reference to the child at the given position.

source

pub fn row_mut(&mut self, id: usize) -> &mut ListChild

Gives mutable access to the child at the given position.

§Panics

Panics if id >= self.len().

source

pub fn set_children(&mut self, children: Vec<ListChild>)

Sets the children for this view.

source

pub fn add_child<V: IntoBoxedView + 'static>( &mut self, label: impl Into<String>, view: V, )

Adds a view to the end of the list.

source

pub fn clear(&mut self)

Removes all children from this view.

source

pub fn child<V: IntoBoxedView + 'static>(self, label: &str, view: V) -> Self

Adds a view to the end of the list.

Chainable variant.

source

pub fn add_delimiter(&mut self)

Adds a delimiter to the end of the list.

source

pub fn delimiter(self) -> Self

Adds a delimiter to the end of the list.

Chainable variant.

source

pub fn remove_child(&mut self, index: usize) -> ListChild

Removes a child from the view.

§Panics

If index >= self.len().

source

pub fn set_on_select<F>(&mut self, cb: F)
where F: Fn(&mut Cursive, &String) + 'static + Send + Sync,

Sets a callback to be used when an item is selected.

source

pub fn on_select_cb<F: Fn(&mut Cursive, &String) + 'static + Send + Sync>( cb: F, ) -> Arc<dyn Fn(&mut Cursive, &String) + Send + Sync>

Helper method to store a callback of the correct type for Self::set_on_select.

This is mostly useful when using this view in a template.

source

pub fn set_on_select_cb( &mut self, cb: Arc<dyn Fn(&mut Cursive, &String) + Send + Sync>, )

Helper method to call Self::set_on_select with a variable from a config.

This is mostly useful when writing a cursive blueprint for this view.

source

pub fn on_select<F>(self, cb: F) -> Self
where F: Fn(&mut Cursive, &String) + 'static + Send + Sync,

Sets a callback to be used when an item is selected.

Chainable variant.

source

pub fn focus(&self) -> usize

Returns the index of the currently focused item.

Panics if the list is empty.

Trait Implementations§

source§

impl Default for ListView

source§

fn default() -> Self

Returns the “default value” for a type. Read more
source§

impl View for ListView

source§

fn draw(&self, printer: &Printer<'_, '_>)

Draws the view with the given printer (includes bounds) and focus. Read more
source§

fn required_size(&mut self, req: Vec2) -> Vec2

Returns the minimum size the view requires with the given restrictions. Read more
source§

fn layout(&mut self, size: Vec2)

Called once the size for this view has been decided. Read more
source§

fn on_event(&mut self, event: Event) -> EventResult

Called when an event is received (key press, mouse event, …). Read more
source§

fn take_focus(&mut self, source: Direction) -> Result<EventResult, CannotFocus>

Attempt to give this view the focus. Read more
source§

fn call_on_any(&mut self, selector: &Selector<'_>, callback: AnyCb<'_>)

Runs a closure on the view identified by the given selector. Read more
source§

fn focus_view( &mut self, selector: &Selector<'_>, ) -> Result<EventResult, ViewNotFound>

Moves the focus to the view identified by the given selector. Read more
source§

fn important_area(&self, size: Vec2) -> Rect

What part of the view is important and should be visible? Read more
source§

fn needs_relayout(&self) -> bool

Should return true if the view content changed since the last call to layout(). Read more
source§

fn type_name(&self) -> &'static str

Returns the type of this view. Read more

Auto Trait Implementations§

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> AnyView for T
where T: View,

source§

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

Downcast self to a Any.

source§

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

Downcast self to a mutable Any.

source§

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

Returns a boxed any from a boxed 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> Finder for T
where T: View,

source§

fn call_on_all<V, F>(&mut self, sel: &Selector<'_>, callback: F)
where V: View, F: FnMut(&mut V),

Runs a callback on all views identified by sel. Read more
source§

fn call_on<V, F, R>(&mut self, sel: &Selector<'_>, callback: F) -> Option<R>
where V: View, F: FnOnce(&mut V) -> R,

Runs a callback on the view identified by sel. Read more
source§

fn call_on_name<V, F, R>(&mut self, name: &str, callback: F) -> Option<R>
where V: View, F: FnOnce(&mut V) -> R,

Convenient method to use call_on with a view::Selector::Name.
source§

fn find_name<V>(&mut self, name: &str) -> Option<ViewRef<V>>
where V: View,

Convenient method to find a view wrapped in an NamedView.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

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> IntoBoxedView for T
where T: View,

source§

fn into_boxed_view(self) -> Box<dyn View>

Returns a Box<View>.
source§

impl<T> Nameable for T
where T: View,

source§

fn with_name<S: Into<String>>(self, name: S) -> NamedView<Self>

Wraps this view into an NamedView with the given id. Read more
source§

impl<T> Resizable for T
where T: View,

source§

fn resized( self, width: SizeConstraint, height: SizeConstraint, ) -> ResizedView<Self>

Wraps self in a ResizedView with the given size constraints.
source§

fn fixed_size<S: Into<Vec2>>(self, size: S) -> ResizedView<Self>

Wraps self into a fixed-size ResizedView.
source§

fn fixed_width(self, width: usize) -> ResizedView<Self>

Wraps self into a fixed-width ResizedView.
source§

fn fixed_height(self, height: usize) -> ResizedView<Self>

Wraps self into a fixed-width ResizedView.
source§

fn full_screen(self) -> ResizedView<Self>

Wraps self into a full-screen ResizedView.
source§

fn full_width(self) -> ResizedView<Self>

Wraps self into a full-width ResizedView.
source§

fn full_height(self) -> ResizedView<Self>

Wraps self into a full-height ResizedView.
source§

fn max_size<S: Into<Vec2>>(self, size: S) -> ResizedView<Self>

Wraps self into a limited-size ResizedView.
source§

fn max_width(self, max_width: usize) -> ResizedView<Self>

Wraps self into a limited-width ResizedView.
source§

fn max_height(self, max_height: usize) -> ResizedView<Self>

Wraps self into a limited-height ResizedView.
source§

fn min_size<S: Into<Vec2>>(self, size: S) -> ResizedView<Self>

Wraps self into a ResizedView at least sized size.
source§

fn min_width(self, min_width: usize) -> ResizedView<Self>

Wraps self in a ResizedView at least min_width wide.
source§

fn min_height(self, min_height: usize) -> ResizedView<Self>

Wraps self in a ResizedView at least min_height tall.
source§

impl<T> Scrollable for T
where T: View,

source§

fn scrollable(self) -> ScrollView<Self>

Wraps self in a ScrollView.
source§

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

§

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>,

§

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> With for T

source§

fn wrap_with<U, F: FnOnce(Self) -> U>(self, f: F) -> U

Calls the given closure and return the result. Read more
source§

fn with<F: FnOnce(&mut Self)>(self, f: F) -> Self

Calls the given closure on self.
source§

fn try_with<E, F>(self, f: F) -> Result<Self, E>
where F: FnOnce(&mut Self) -> Result<(), E>,

Calls the given closure on self.
source§

fn with_if<F>(self, condition: bool, f: F) -> Self
where F: FnOnce(&mut Self),

Calls the given closure if condition == true.