rat_focus

Struct FocusBuilder

source
pub struct FocusBuilder { /* private fields */ }
Expand description

Builder for the Focus.

Implementations§

source§

impl FocusBuilder

source

pub fn new(last: Option<Focus>) -> FocusBuilder

source

pub fn enable_log(self) -> Self

source

pub fn container(&mut self, container: &dyn HasFocus) -> &mut Self

Add a container widget.

Adds start+end and calls container.build()

source

pub fn widget(&mut self, widget: &dyn HasFocusFlag) -> &mut Self

Add a widget.

The widget is added to all open containers.

source

pub fn start( &mut self, container_flag: Option<ContainerFlag>, area: Rect, ) -> Option<ContainerFlag>

Manually start a container widget. Must be matched with the equivalent end.

Use of container is preferred.

Attention If container_flag is None a dummy flag will be created and returned. Use the returned value when calling end.

source

pub fn end(&mut self, container_flag: Option<ContainerFlag>)

Manually end a container widget.

Use of container is preferred.

source

pub fn build(self) -> Focus

Build the final focus.

If old is given, all widgets/containers no longer in the focus list are cleared().

source

pub fn for_container(container: &dyn HasFocus) -> Focus

Shortcut for building the focus for a container that implements HasFocus.

This creates a fresh Focus.

See Use rebuild if you want to ensure that widgets that are no longer in the widget structure have their focus flag reset properly. If you don’t have some logic to conditionally add widgets to the focus, this function is probably fine.

source

pub fn rebuild(container: &dyn HasFocus, old: Option<Focus>) -> Focus

Shortcut function for building the focus for a container that implements HasFocus

This takes the old Focus and reuses most of its allocations. It also ensures that any widgets no longer in the widget structure have their focus-flags reset.

Trait Implementations§

source§

impl Debug for FocusBuilder

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for FocusBuilder

source§

fn default() -> FocusBuilder

Returns the “default value” for a type. 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> 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> 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> 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, 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.