zng/popup.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46
//! Popup widget and properties.
//!
//! A popup is a temporary *flyover* inserted as a top-most layer using [`POPUP`] service. The service works
//! as an extension of the [`LAYERS`](crate::layer::LAYERS) service that implements the concept of *open* and *close* and
//! close requests. The [`Popup!`](struct@Popup) widget is a styleable container that is a good popup root widget.
//!
//! ```
//! use zng::prelude::*;
//! # let _scope = APP.defaults();
//!
//!
//! let mut popup = None;
//! let is_closed = var(true);
//! # let _ =
//! Button! {
//! layout::align = layout::Align::CENTER;
//! child = Text!(is_closed.map(|&b| if b { "Open Popup" } else { "Close Popup" }.into()));
//! on_click = hn!(|_| {
//! if is_closed.get() {
//! let p = POPUP.open(zng::popup::Popup! {
//! child = Text!("Popup content!");
//! });
//! p.bind_map(&is_closed, |s| matches!(s, zng::popup::PopupState::Closed)).perm();
//! popup = Some(p);
//! } else if let Some(p) = popup.take() {
//! POPUP.close(&p);
//! }
//! })
//! }
//! # ;
//! ```
//!
//! The example above declares a button that opens and closes a popup
//!
//! Note that the toggle widget provides a [combo](crate::toggle#Combo) style and the [`checked_popup`](struct@crate::toggle::Toggle#checked_popup)
//! property that implements a similar behavior.
//!
//! # Full API
//!
//! See [`zng_wgt_layer::popup`] for the full widget API.
pub use zng_wgt_layer::popup::{
anchor_mode, close_delay, close_on_focus_leave, context_capture, is_close_delaying, on_popup_close_requested,
on_pre_popup_close_requested, style_fn, ContextCapture, DefaultStyle, Popup, PopupCloseMode, PopupCloseRequestedArgs, PopupState,
POPUP, POPUP_CLOSE_CMD, POPUP_CLOSE_REQUESTED_EVENT,
};