Allow items to be assigned to multiple popovers
This commit is contained in:
parent
f05dfc74da
commit
2fd62d090a
2 changed files with 33 additions and 23 deletions
|
@ -113,28 +113,11 @@ static NSString* const ImageScrubberItemIdentifier = @"scrubber.image.item";
|
||||||
return nil;
|
return nil;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
- (void)refreshTouchBarItem:(NSTouchBar*)touchBar
|
- (void)refreshTouchBarItem:(NSTouchBar*)touchBar
|
||||||
id:(const std::string&)item_id {
|
id:(NSTouchBarItemIdentifier)identifier
|
||||||
if (![self hasItemWithID:item_id]) return;
|
withType:(std::string)item_type
|
||||||
|
withSettings:(mate::PersistentDictionary)settings {
|
||||||
mate::PersistentDictionary settings = settings_[item_id];
|
NSTouchBarItem* item = [touchBar itemForIdentifier:identifier];
|
||||||
std::string item_type;
|
|
||||||
settings.Get("type", &item_type);
|
|
||||||
|
|
||||||
NSTouchBarItemIdentifier identifier = [self identifierFromID:item_id
|
|
||||||
type:item_type];
|
|
||||||
if (!identifier) return;
|
|
||||||
|
|
||||||
NSTouchBar* targetTouchBar = touchBar;
|
|
||||||
|
|
||||||
std::string popover_id;
|
|
||||||
if (settings.Get("_popover", &popover_id)) {
|
|
||||||
NSPopoverTouchBarItem* popoverItem = [touchBar itemForIdentifier:[self identifierFromID:popover_id type:"popover"]];
|
|
||||||
targetTouchBar = popoverItem.popoverTouchBar;
|
|
||||||
}
|
|
||||||
|
|
||||||
NSTouchBarItem* item = [targetTouchBar itemForIdentifier:identifier];
|
|
||||||
if (!item) return;
|
if (!item) return;
|
||||||
|
|
||||||
if (item_type == "button") {
|
if (item_type == "button") {
|
||||||
|
@ -174,6 +157,30 @@ static NSString* const ImageScrubberItemIdentifier = @"scrubber.image.item";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- (void)refreshTouchBarItem:(NSTouchBar*)touchBar
|
||||||
|
id:(const std::string&)item_id {
|
||||||
|
if (![self hasItemWithID:item_id]) return;
|
||||||
|
|
||||||
|
mate::PersistentDictionary settings = settings_[item_id];
|
||||||
|
std::string item_type;
|
||||||
|
settings.Get("type", &item_type);
|
||||||
|
|
||||||
|
NSTouchBarItemIdentifier identifier = [self identifierFromID:item_id
|
||||||
|
type:item_type];
|
||||||
|
if (!identifier) return;
|
||||||
|
|
||||||
|
std::vector<std::string> popover_ids;
|
||||||
|
if (settings.Get("_popover", &popover_ids)) {
|
||||||
|
for (size_t i = 0; i < popover_ids.size(); ++i) {
|
||||||
|
std::string popover_id = popover_ids[i];
|
||||||
|
NSPopoverTouchBarItem* popoverItem = [touchBar itemForIdentifier:[self identifierFromID:popover_id type:"popover"]];
|
||||||
|
NSTouchBar* targetTouchBar = popoverItem.popoverTouchBar;
|
||||||
|
[self refreshTouchBarItem:targetTouchBar id:identifier withType:item_type withSettings:settings];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
[self refreshTouchBarItem:touchBar id:identifier withType:item_type withSettings:settings];
|
||||||
|
}
|
||||||
|
|
||||||
- (void)buttonAction:(id)sender {
|
- (void)buttonAction:(id)sender {
|
||||||
NSString* item_id = [NSString stringWithFormat:@"%ld", ((NSButton*)sender).tag];
|
NSString* item_id = [NSString stringWithFormat:@"%ld", ((NSButton*)sender).tag];
|
||||||
window_->NotifyTouchBarItemInteraction([item_id UTF8String],
|
window_->NotifyTouchBarItemInteraction([item_id UTF8String],
|
||||||
|
|
|
@ -223,7 +223,10 @@ TouchBar.TouchBarPopover = class TouchBarPopover extends TouchBarItem {
|
||||||
if (!(this.child instanceof TouchBar)) {
|
if (!(this.child instanceof TouchBar)) {
|
||||||
this.child = new TouchBar(this.child)
|
this.child = new TouchBar(this.child)
|
||||||
}
|
}
|
||||||
this.child.ordereredItems.forEach((item) => item._popover = this.id)
|
this.child.ordereredItems.forEach((item) => {
|
||||||
|
item._popover = item._popover || []
|
||||||
|
if (!item._popover.find(itemID => itemID === this.id)) item._popover.push(this.id)
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue