mirror of
https://github.com/danbulant/cushy
synced 2026-06-24 17:12:11 +00:00
Removed ChosenMenuItem
Also updated the changelog
This commit is contained in:
parent
c5f1832b3e
commit
07f1febe9f
2 changed files with 10 additions and 18 deletions
|
|
@ -71,6 +71,9 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||||
- `Button::on_click` now takes a `Option<ButtonClick>` structure. When this
|
- `Button::on_click` now takes a `Option<ButtonClick>` structure. When this
|
||||||
value is provided, information about the mouse click that caused the event is
|
value is provided, information about the mouse click that caused the event is
|
||||||
provided.
|
provided.
|
||||||
|
- `OverlayBuilder` has hade many of its functions moved into a new trait,
|
||||||
|
`Overlayable`. This is to ensure common API surfaces across all overlayable
|
||||||
|
widgets including the new `Menu` widget.
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
|
|
||||||
|
|
@ -246,6 +249,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||||
`ModifiersState` types. This trait adds helpers for dealing with
|
`ModifiersState` types. This trait adds helpers for dealing with
|
||||||
platform-specific meanings for keyboard modifiers.
|
platform-specific meanings for keyboard modifiers.
|
||||||
- `OverlayLayer::dismiss_all()` dismisses all overlays immediately.
|
- `OverlayLayer::dismiss_all()` dismisses all overlays immediately.
|
||||||
|
- `Menu` is a new widget type that can be shown in an `OverlayLayer` to create
|
||||||
|
contextual menus or other popup menus.
|
||||||
|
|
||||||
[plotters]: https://github.com/plotters-rs/plotters
|
[plotters]: https://github.com/plotters-rs/plotters
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -12,7 +12,7 @@ use kludgine::DrawableExt;
|
||||||
use parking_lot::Mutex;
|
use parking_lot::Mutex;
|
||||||
|
|
||||||
use self::sealed::{SharedMenuState, SubmenuFactory};
|
use self::sealed::{SharedMenuState, SubmenuFactory};
|
||||||
use super::button::{ButtonClick, ButtonColors, ButtonKind, VisualState};
|
use super::button::{ButtonColors, ButtonKind, VisualState};
|
||||||
use super::container::{self, ContainerShadow};
|
use super::container::{self, ContainerShadow};
|
||||||
use super::disclose::IndicatorSize;
|
use super::disclose::IndicatorSize;
|
||||||
use super::layers::{OverlayBuilder, OverlayHandle, OverlayLayer, Overlayable};
|
use super::layers::{OverlayBuilder, OverlayHandle, OverlayLayer, Overlayable};
|
||||||
|
|
@ -74,7 +74,7 @@ where
|
||||||
#[must_use]
|
#[must_use]
|
||||||
pub fn on_selected<F>(self, selected: F) -> Menu<T>
|
pub fn on_selected<F>(self, selected: F) -> Menu<T>
|
||||||
where
|
where
|
||||||
F: FnMut(ChosenMenuItem<T>) + Send + 'static,
|
F: FnMut(T) + Send + 'static,
|
||||||
{
|
{
|
||||||
Menu {
|
Menu {
|
||||||
items: self.items,
|
items: self.items,
|
||||||
|
|
@ -234,16 +234,6 @@ impl OpenMenuHandle {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// The selected item of a shown [`Menu<T>`].
|
|
||||||
#[derive(Debug, Clone, Copy, Eq, PartialEq)]
|
|
||||||
pub struct ChosenMenuItem<T> {
|
|
||||||
/// The item that was chosen.
|
|
||||||
pub item: T,
|
|
||||||
/// Information about the button click that caused this item to be chosen,
|
|
||||||
/// if present.
|
|
||||||
pub click: Option<ButtonClick>,
|
|
||||||
}
|
|
||||||
|
|
||||||
/// A builder of a [`MenuItem<T>`].
|
/// A builder of a [`MenuItem<T>`].
|
||||||
pub struct MenuItemBuilder<T, Contents = ()> {
|
pub struct MenuItemBuilder<T, Contents = ()> {
|
||||||
value: T,
|
value: T,
|
||||||
|
|
@ -458,9 +448,9 @@ where
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// A handler for a [`ChosenMenuItem<T>`].
|
/// A handler for a selected [`MenuItem<T>`].
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct MenuHandler<T>(Arc<Mutex<Callback<ChosenMenuItem<T>>>>);
|
pub struct MenuHandler<T>(Arc<Mutex<Callback<T>>>);
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
struct OpenMenu<T> {
|
struct OpenMenu<T> {
|
||||||
|
|
@ -769,10 +759,7 @@ where
|
||||||
let ItemKind::Item(item) = &self.items[index].item else {
|
let ItemKind::Item(item) = &self.items[index].item else {
|
||||||
return;
|
return;
|
||||||
};
|
};
|
||||||
self.on_click.0.lock().invoke(ChosenMenuItem {
|
self.on_click.0.lock().invoke(item.value.clone());
|
||||||
item: item.value.clone(),
|
|
||||||
click: None,
|
|
||||||
});
|
|
||||||
let mut shared = self.shared.lock();
|
let mut shared = self.shared.lock();
|
||||||
for handle in shared.open_menus.drain() {
|
for handle in shared.open_menus.drain() {
|
||||||
handle.dismiss();
|
handle.dismiss();
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue