fix: allow NSMenuItems to be disabled (#46307)
* fix: disable NSMenu autoenable feature to allow disabling of NSMenuItems * style: fix linter issues and update comments * chore: remove unneeded comment
This commit is contained in:
parent
e09712f0e1
commit
ac616ef41d
1 changed files with 9 additions and 6 deletions
|
@ -320,6 +320,10 @@ NSArray* ConvertSharingItemToNS(const SharingItem& item) {
|
|||
NSMenuItem* item = [[NSMenuItem alloc] initWithTitle:label
|
||||
action:@selector(itemSelected:)
|
||||
keyEquivalent:@""];
|
||||
if (model->IsEnabledAt(index))
|
||||
[item setEnabled:YES];
|
||||
else
|
||||
[item setEnabled:NO];
|
||||
|
||||
// If the menu item has an icon, set it.
|
||||
ui::ImageModel icon = model->GetIconAt(index);
|
||||
|
@ -349,11 +353,6 @@ NSArray* ConvertSharingItemToNS(const SharingItem& item) {
|
|||
[item setSubmenu:[self createShareMenuForItem:sharing_item]];
|
||||
} else if (type == electron::ElectronMenuModel::TYPE_SUBMENU &&
|
||||
model->IsVisibleAt(index)) {
|
||||
// We need to specifically check that the submenu top-level item has been
|
||||
// enabled as it's not validated by validateUserInterfaceItem
|
||||
if (!model->IsEnabledAt(index))
|
||||
[item setEnabled:NO];
|
||||
|
||||
// Recursively build a submenu from the sub-model at this index.
|
||||
[item setTarget:nil];
|
||||
[item setAction:nil];
|
||||
|
@ -493,8 +492,10 @@ NSArray* ConvertSharingItemToNS(const SharingItem& item) {
|
|||
}
|
||||
|
||||
- (NSMenu*)menu {
|
||||
if (menu_)
|
||||
if (menu_) {
|
||||
[menu_ setAutoenablesItems:NO];
|
||||
return menu_;
|
||||
}
|
||||
|
||||
if (model_ && model_->sharing_item()) {
|
||||
NSMenu* menu = [self createShareMenuForItem:*model_->sharing_item()];
|
||||
|
@ -504,6 +505,8 @@ NSArray* ConvertSharingItemToNS(const SharingItem& item) {
|
|||
if (model_)
|
||||
[self populateWithModel:model_.get()];
|
||||
}
|
||||
|
||||
[menu_ setAutoenablesItems:NO];
|
||||
[menu_ setDelegate:self];
|
||||
return menu_;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue