mirror of
https://github.com/italicsjenga/muda.git
synced 2025-01-11 12:21:30 +11:00
Implement macOS Submenu label
, enabled
(#3)
* fix panic in label better * implement macos Submenu `enabled` state
This commit is contained in:
parent
1ab9c9b9e8
commit
125628b1ff
|
@ -92,7 +92,7 @@ impl TextMenuItem {
|
||||||
|
|
||||||
pub fn enabled(&self) -> bool {
|
pub fn enabled(&self) -> bool {
|
||||||
unsafe {
|
unsafe {
|
||||||
let enabled: BOOL = msg_send![self.ns_menu_item, enabled];
|
let enabled: BOOL = msg_send![self.ns_menu_item, isEnabled];
|
||||||
enabled
|
enabled
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,16 +22,21 @@ impl Menu {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn add_submenu(&mut self, label: impl AsRef<str>, enabled: bool) -> Submenu {
|
pub fn add_submenu(&mut self, label: impl AsRef<str>, enabled: bool) -> Submenu {
|
||||||
let mut sub_menu = Submenu(Menu::new());
|
let menu = Menu::new();
|
||||||
sub_menu.set_label(label.as_ref());
|
let menu_item = TextMenuItem::new(
|
||||||
sub_menu.set_enabled(enabled);
|
"",
|
||||||
let item = TextMenuItem::new(label, enabled, sel!(fireMenubarAction:));
|
enabled,
|
||||||
|
sel!(fireMenubarAction:),
|
||||||
|
);
|
||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
item.ns_menu_item.setSubmenu_(sub_menu.0 .0);
|
menu_item.ns_menu_item.setSubmenu_(menu.0);
|
||||||
self.0.addItem_(item.ns_menu_item);
|
self.0.addItem_(menu_item.ns_menu_item);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let mut sub_menu = Submenu { menu, menu_item };
|
||||||
|
sub_menu.set_label(label);
|
||||||
|
|
||||||
sub_menu
|
sub_menu
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -43,34 +48,40 @@ impl Menu {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct Submenu(Menu);
|
pub struct Submenu {
|
||||||
|
pub(crate) menu: Menu,
|
||||||
|
pub(crate) menu_item: TextMenuItem,
|
||||||
|
}
|
||||||
|
|
||||||
impl Submenu {
|
impl Submenu {
|
||||||
pub fn label(&self) -> String {
|
pub fn label(&self) -> String {
|
||||||
todo!()
|
self.menu_item.label()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_label(&mut self, label: impl AsRef<str>) {
|
pub fn set_label(&mut self, label: impl AsRef<str>) {
|
||||||
|
self.menu_item.set_label(label.as_ref().to_string());
|
||||||
unsafe {
|
unsafe {
|
||||||
let menu_title = NSString::alloc(nil).init_str(label.as_ref());
|
let menu_title = NSString::alloc(nil).init_str(label.as_ref());
|
||||||
let () = msg_send![self.0 .0, setTitle: menu_title];
|
let () = msg_send![self.menu.0, setTitle: menu_title];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn enabled(&self) -> bool {
|
pub fn enabled(&self) -> bool {
|
||||||
true
|
self.menu_item.enabled()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_enabled(&mut self, _enabled: bool) {}
|
pub fn set_enabled(&mut self, _enabled: bool) {
|
||||||
|
self.menu_item.set_enabled(_enabled)
|
||||||
|
}
|
||||||
|
|
||||||
pub fn add_submenu(&mut self, label: impl AsRef<str>, enabled: bool) -> Submenu {
|
pub fn add_submenu(&mut self, label: impl AsRef<str>, enabled: bool) -> Submenu {
|
||||||
self.0.add_submenu(label, enabled)
|
self.menu.add_submenu(label, enabled)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn add_text_item(&mut self, label: impl AsRef<str>, enabled: bool) -> TextMenuItem {
|
pub fn add_text_item(&mut self, label: impl AsRef<str>, enabled: bool) -> TextMenuItem {
|
||||||
let item = TextMenuItem::new(label, enabled, sel!(fireMenubarAction:));
|
let item = TextMenuItem::new(label, enabled, sel!(fireMenubarAction:));
|
||||||
unsafe {
|
unsafe {
|
||||||
self.0 .0.addItem_(item.ns_menu_item);
|
self.menu.0.addItem_(item.ns_menu_item);
|
||||||
}
|
}
|
||||||
item
|
item
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue