Struct TabPanel

Source
pub struct TabPanel { /* private fields */ }
Expand description

The TabPanel is an ease of use wrapper around a TabView and its TabBar. Additionally the TabBar in the Panel can be horizontally aligned, by default it is set to be left aligned.

§Example

use cursive_tabs::{Align, TabPanel};
use cursive::views::TextView;
use cursive::view::Nameable;

let mut tabs = TabPanel::new()
      .with_tab(TextView::new("First").with_name("First"))
      .with_tab(TextView::new("Second").with_name("Second"))
      .with_bar_alignment(Align::Center);

A TabView is also usable separately, so if you prefer the tabs without the TabBar and Panel around have a look at TabView.

Implementations§

Source§

impl TabPanel

Source

pub fn new() -> Self

Returns a new instance of a TabPanel. Alignment is set by default to left, to change this use set_bar_alignment to change to any other HAlign provided by cursive.

Source

pub fn active_tab(&self) -> Option<&str>

Returns the current active tab of the TabView. Note: Calls active_tab on the enclosed TabView.

Source

pub fn active_view(&self) -> Option<&dyn View>

Returns a reference to the underlying view.

Source

pub fn active_view_mut(&mut self) -> Option<&mut dyn View>

Returns a mutable reference to the underlying view.

Source

pub fn views(&self) -> Vec<&dyn View>

Source

pub fn views_mut(&mut self) -> Vec<&mut dyn View>

Source

pub fn set_active_tab(&mut self, id: &str) -> Result<(), IdNotFound>

Non-consuming variant to set the active tab in the TabView. Note: Calls set_active_tab on the enclosed TabView.

Source

pub fn with_active_tab(self, id: &str) -> Result<Self, Self>

Consuming & Chainable variant to set the active tab in the TabView. Note: Calls set_active_tab on the enclosed TabView.

Source

pub fn add_tab<T: View>(&mut self, view: NamedView<T>)

Non-consuming variant to add new tabs to the TabView. Note: Calls add_tab on the enclosed TabView.

Source

pub fn with_tab<T: View>(self, view: NamedView<T>) -> Self

Consuming & Chainable variant to add a new tab. Note: Calls add_tab on the enclosed TabView.

Source

pub fn swap_tabs(&mut self, fst: &str, snd: &str)

Swaps the given tab keys. If at least one of them cannot be found then no operation is performed

Source

pub fn add_tab_at<T: View>(&mut self, view: NamedView<T>, pos: usize)

Non-consuming variant to add new tabs to the TabView at a certain position. It is fail-safe, if the postion is greater than the amount of tabs, it is appended to the end. Note: Calls add_tab_at on the enclosed TabView.

Source

pub fn with_tab_at<T: View>(self, view: NamedView<T>, pos: usize) -> Self

Consuming & Chainable variant to add a new tab at a certain position. It is fail-safe, if the postion is greater than the amount of tabs, it is appended to the end. Note: Calls add_tab_at on the enclosed TabView.

Source

pub fn remove_tab(&mut self, id: &str) -> Result<(), IdNotFound>

Remove a tab of the enclosed TabView.

Source

pub fn next(&mut self)

Proceeds to the next view in order of addition.

Source

pub fn prev(&mut self)

Go back to the previous view in order of addition.

Source

pub fn with_bar_alignment(self, align: Align) -> Self

Consumable & Chainable variant to set the bar alignment.

Source

pub fn set_bar_alignment(&mut self, align: Align)

Non-consuming variant to set the bar alignment.

Source

pub fn with_bar_placement(self, placement: Placement) -> Self

Source

pub fn set_bar_placement(&mut self, placement: Placement)

Source

pub fn tab_order(&self) -> Vec<String>

Returns the current order of tabs as an Vector with the keys of the views.

Trait Implementations§

Source§

impl Default for TabPanel

Source§

fn default() -> Self

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

impl View for TabPanel

Source§

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

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

fn layout(&mut self, vec: Vec2)

Called once the size for this view has been decided. 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 required_size(&mut self, cst: Vec2) -> Vec2

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

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

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

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

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

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

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

fn call_on_any<'a>(&mut self, slt: &Selector<'_>, cb: AnyCb<'a>)

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

fn important_area(&self, view_size: XY<usize>) -> Rect

What part of the view is important and should be visible? 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>(self, name: S) -> NamedView<Self>
where S: Into<String>,

Wraps this view into an NamedView with the given id. 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> 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>(self, size: S) -> ResizedView<Self>
where S: Into<XY<usize>>,

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>(self, size: S) -> ResizedView<Self>
where S: Into<XY<usize>>,

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>(self, size: S) -> ResizedView<Self>
where S: Into<XY<usize>>,

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

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

Source§

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

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

fn with<F>(self, f: F) -> Self
where F: FnOnce(&mut 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.