Initial support for dynamic properties
This commit is contained in:
parent
cbb6f8c33e
commit
98f5858b11
10 changed files with 46 additions and 33 deletions
|
@ -853,8 +853,8 @@ void Window::SetTouchBar(mate::Arguments* args) {
|
|||
window_->SetTouchBar(args);
|
||||
}
|
||||
|
||||
void Window::RefreshTouchBarItem(mate::Arguments* args) {
|
||||
window_->RefreshTouchBarItem(args);
|
||||
void Window::RefreshTouchBarItem(const std::string& item_id) {
|
||||
window_->RefreshTouchBarItem(item_id);
|
||||
}
|
||||
|
||||
int32_t Window::ID() const {
|
||||
|
|
|
@ -207,7 +207,7 @@ class Window : public mate::TrackableObject<Window>,
|
|||
void SetVibrancy(mate::Arguments* args);
|
||||
void DestroyTouchBar();
|
||||
void SetTouchBar(mate::Arguments* args);
|
||||
void RefreshTouchBarItem(mate::Arguments* args);
|
||||
void RefreshTouchBarItem(const std::string& item_id);
|
||||
|
||||
v8::Local<v8::Value> WebContents(v8::Isolate* isolate);
|
||||
|
||||
|
|
|
@ -347,7 +347,7 @@ void NativeWindow::DestroyTouchBar() {
|
|||
void NativeWindow::SetTouchBar(mate::Arguments* args) {
|
||||
}
|
||||
|
||||
void NativeWindow::RefreshTouchBarItem(mate::Arguments* args) {
|
||||
void NativeWindow::RefreshTouchBarItem(const std::string& item_id) {
|
||||
}
|
||||
|
||||
void NativeWindow::FocusOnWebView() {
|
||||
|
|
|
@ -173,7 +173,7 @@ class NativeWindow : public base::SupportsUserData,
|
|||
// Touchbar API
|
||||
virtual void DestroyTouchBar();
|
||||
virtual void SetTouchBar(mate::Arguments* args);
|
||||
virtual void RefreshTouchBarItem(mate::Arguments* args);
|
||||
virtual void RefreshTouchBarItem(const std::string& item_id);
|
||||
|
||||
// Webview APIs.
|
||||
virtual void FocusOnWebView();
|
||||
|
|
|
@ -104,7 +104,7 @@ class NativeWindowMac : public NativeWindow,
|
|||
void SetVibrancy(const std::string& type) override;
|
||||
void DestroyTouchBar() override;
|
||||
void SetTouchBar(mate::Arguments* args) override;
|
||||
void RefreshTouchBarItem(mate::Arguments* args) override;
|
||||
void RefreshTouchBarItem(const std::string& item_id) override;
|
||||
std::vector<mate::PersistentDictionary> GetTouchBarItems();
|
||||
|
||||
// content::RenderWidgetHost::InputEventObserver:
|
||||
|
|
|
@ -354,7 +354,8 @@ bool ScopedDisableResize::disable_resize_ = false;
|
|||
- (void)setEnableLargerThanScreen:(bool)enable;
|
||||
- (void)enableWindowButtonsOffset;
|
||||
- (void)resetTouchBar;
|
||||
- (void)refreshTouchBarItem:(mate::Arguments*)args;
|
||||
- (void)refreshTouchBarItem:(const std::string&)item_id;
|
||||
|
||||
@end
|
||||
|
||||
@implementation AtomNSWindow
|
||||
|
@ -371,8 +372,8 @@ bool ScopedDisableResize::disable_resize_ = false;
|
|||
self.touchBar = nil;
|
||||
}
|
||||
|
||||
- (void)refreshTouchBarItem:(mate::Arguments*)args {
|
||||
[atom_touch_bar_ refreshTouchBarItem:args];
|
||||
- (void)refreshTouchBarItem:(const std::string&)item_id {
|
||||
[atom_touch_bar_ refreshTouchBarItem:item_id];
|
||||
}
|
||||
|
||||
- (NSTouchBar*)makeTouchBar {
|
||||
|
@ -1381,8 +1382,8 @@ void NativeWindowMac::SetTouchBar(mate::Arguments* args) {
|
|||
}
|
||||
}
|
||||
|
||||
void NativeWindowMac::RefreshTouchBarItem(mate::Arguments* args) {
|
||||
[window_ refreshTouchBarItem:args];
|
||||
void NativeWindowMac::RefreshTouchBarItem(const std::string& item_id) {
|
||||
[window_ refreshTouchBarItem:item_id];
|
||||
}
|
||||
|
||||
std::vector<mate::PersistentDictionary> NativeWindowMac::GetTouchBarItems() {
|
||||
|
|
|
@ -30,7 +30,7 @@
|
|||
- (NSTouchBar*)makeTouchBarFromItemOptions:(const std::vector<mate::PersistentDictionary>&)item_options;
|
||||
- (NSTouchBar*)touchBarFromItemIdentifiers:(NSMutableArray*)items;
|
||||
- (NSMutableArray*)identifierArrayFromDicts:(const std::vector<mate::PersistentDictionary>&)dicts;
|
||||
- (void)refreshTouchBarItem:(mate::Arguments*)args;
|
||||
- (void)refreshTouchBarItem:(const std::string&)item_id;
|
||||
- (void)clear;
|
||||
|
||||
- (NSString*)idFromIdentifier:(NSString*)identifier withPrefix:(NSString*)prefix;
|
||||
|
|
|
@ -101,32 +101,29 @@ static NSTouchBarItemIdentifier SliderIdentifier = @"com.electron.touchbar.slide
|
|||
}
|
||||
|
||||
|
||||
- (void)refreshTouchBarItem:(mate::Arguments*)args {
|
||||
std::string item_id;
|
||||
std::string type;
|
||||
mate::PersistentDictionary options;
|
||||
if (!args->GetNext(&options)) return;
|
||||
if (!options.Get("type", &type)) return;
|
||||
if (!options.Get("id", &item_id)) return;
|
||||
- (void)refreshTouchBarItem:(const std::string&)item_id {
|
||||
if (item_map.find(item_id) == item_map.end()) return;
|
||||
if (![self hasItemWithID:item_id]) return;
|
||||
|
||||
if (type == "button") {
|
||||
mate::PersistentDictionary options = item_id_map[item_id];
|
||||
std::string item_type;
|
||||
options.Get("type", &item_type);
|
||||
|
||||
if (item_type == "button") {
|
||||
[self updateButton:(NSCustomTouchBarItem*)item_map[item_id]
|
||||
withOptions:options];
|
||||
} else if (type == "label") {
|
||||
} else if (item_type == "label") {
|
||||
[self updateLabel:(NSCustomTouchBarItem*)item_map[item_id]
|
||||
withOptions:options];
|
||||
} else if (type == "colorpicker") {
|
||||
} else if (item_type == "colorpicker") {
|
||||
[self updateColorPicker:(NSColorPickerTouchBarItem*)item_map[item_id]
|
||||
withOptions:options];
|
||||
} else if (type == "slider") {
|
||||
} else if (item_type == "slider") {
|
||||
[self updateSlider:(NSSliderTouchBarItem*)item_map[item_id]
|
||||
withOptions:options];
|
||||
} else if (type == "popover") {
|
||||
} else if (item_type == "popover") {
|
||||
[self updatePopover:(NSPopoverTouchBarItem*)item_map[item_id]
|
||||
withOptions:options];
|
||||
} else if (type == "group") {
|
||||
args->ThrowError("You can not update the config of a group. Update the individual items or replace the group");
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue