PopupBuilder

Struct PopupBuilder 

Source
pub struct PopupBuilder<State = Unbound> { /* private fields */ }
Expand description

Builder for configuring popups

The builder uses phantom types to ensure compile-time safety:

§Example

shell.on("Main", "open_menu", |control| {
    let popup_handle = control.popups().builder("MenuPopup")
        .at_cursor()
        .grab(true)
        .close_on("menu_closed")
        .show()?;
});

Implementations§

Source§

impl PopupBuilder<Unbound>

Source

pub fn new(component: impl Into<String>) -> Self

Creates a new popup builder for the specified component

This builder is unbound and cannot show popups directly. Use PopupShell::builder to create a bound builder that can call .show().

Source§

impl<State> PopupBuilder<State>

Source

pub fn position(self, position: PopupPosition) -> Self

Source

pub fn at_cursor(self) -> Self

Source

pub fn at_position(self, x: f32, y: f32) -> Self

Source

pub fn centered(self) -> Self

Source

pub fn relative_to_rect( self, rect: LogicalRect, anchor: AnchorPoint, alignment: Alignment, ) -> Self

Source

pub fn offset(self, x: f32, y: f32) -> Self

Source

pub fn size(self, size: PopupSize) -> Self

Source

pub fn fixed_size(self, width: f32, height: f32) -> Self

Source

pub fn min_size(self, width: f32, height: f32) -> Self

Source

pub fn max_size(self, width: f32, height: f32) -> Self

Source

pub fn content_sized(self) -> Self

Source

pub fn grab(self, enable: bool) -> Self

Source

pub fn modal(self, enable: bool) -> Self

Source

pub fn close_on_click_outside(self) -> Self

Source

pub fn close_on_escape(self) -> Self

Source

pub fn constraint_adjustment(self, adjustment: ConstraintAdjustment) -> Self

Source

pub fn on_output(self, target: OutputTarget) -> Self

Source

pub fn on_primary(self) -> Self

Source

pub fn on_active(self) -> Self

Source

pub fn parent(self, parent: PopupHandle) -> Self

Source

pub const fn z_index(self, index: i32) -> Self

Source

pub fn close_on(self, callback_name: impl Into<String>) -> Self

Source

pub fn resize_on(self, callback_name: impl Into<String>) -> Self

Source

pub fn build(self) -> PopupConfig

Builds the configuration without showing the popup

Returns a PopupConfig that can be shown later using PopupShell::show.

Source§

impl PopupBuilder<Bound>

Source

pub fn show(self) -> Result<PopupHandle>

Shows the popup with the configured settings

This method is only available on builders created via PopupShell::builder, ensuring at compile time that the builder has access to a shell.

Auto Trait Implementations§

§

impl<State> Freeze for PopupBuilder<State>
where State: Freeze,

§

impl<State> RefUnwindSafe for PopupBuilder<State>
where State: RefUnwindSafe,

§

impl<State> Send for PopupBuilder<State>
where State: Send,

§

impl<State> Sync for PopupBuilder<State>
where State: Sync,

§

impl<State> Unpin for PopupBuilder<State>
where State: Unpin,

§

impl<State> UnwindSafe for PopupBuilder<State>
where State: UnwindSafe,

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> DowncastSync for T
where T: Any + Send + Sync,

Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
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, 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