// Copyright 2016 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "base/strings/sys_string_conversions.h"
#import "components/remote_cocoa/app_shim/bridged_content_view.h"
#import "components/remote_cocoa/app_shim/native_widget_ns_window_bridge.h"
#include "components/remote_cocoa/common/native_widget_ns_window_host.mojom.h"
#include "ui/base/mojom/dialog_button.mojom.h"
namespace {
NSString* const kTouchBarDialogButtonsGroupId =
@"com.google.chrome-DIALOG-BUTTONS-GROUP";
NSString* const kTouchBarOKId = @"com.google.chrome-OK";
NSString* const kTouchBarCancelId = @"com.google.chrome-CANCEL";
} // namespace
@interface BridgedContentView (TouchBarAdditions) <NSTouchBarDelegate>
- (void)touchBarButtonAction:(id)sender;
@end
@implementation BridgedContentView (TouchBarAdditions)
- (void)touchBarButtonAction:(id)sender {
ui::mojom::DialogButton type =
static_cast<ui::mojom::DialogButton>([sender tag]);
if (_bridge)
_bridge->host()->DoDialogButtonAction(type);
}
// NSTouchBarDelegate protocol implementation.
- (NSTouchBarItem*)touchBar:(NSTouchBar*)touchBar
makeItemForIdentifier:(NSTouchBarItemIdentifier)identifier {
if (!_bridge)
return nil;
if ([identifier isEqualToString:kTouchBarDialogButtonsGroupId]) {
NSMutableArray* items = [NSMutableArray arrayWithCapacity:2];
for (NSTouchBarItemIdentifier i in @[ kTouchBarCancelId, kTouchBarOKId ]) {
NSTouchBarItem* item = [self touchBar:touchBar makeItemForIdentifier:i];
if (item)
[items addObject:item];
}
if ([items count] == 0)
return nil;
return [NSClassFromString(@"NSGroupTouchBarItem")
groupItemWithIdentifier:identifier
items:items];
}
ui::mojom::DialogButton type = ui::mojom::DialogButton::kNone;
if ([identifier isEqualToString:kTouchBarOKId])
type = ui::mojom::DialogButton::kOk;
else if ([identifier isEqualToString:kTouchBarCancelId])
type = ui::mojom::DialogButton::kCancel;
else
return nil;
bool buttonExists = false;
std::u16string buttonLabel;
bool isButtonEnabled = false;
bool isButtonDefault = false;
_bridge->host()->GetDialogButtonInfo(type, &buttonExists, &buttonLabel,
&isButtonEnabled, &isButtonDefault);
if (!buttonExists)
return nil;
NSCustomTouchBarItem* item = [[NSClassFromString(@"NSCustomTouchBarItem")
alloc] initWithIdentifier:identifier];
NSButton* button =
[NSButton buttonWithTitle:base::SysUTF16ToNSString(buttonLabel)
target:self
action:@selector(touchBarButtonAction:)];
if (isButtonDefault) {
// NSAlert uses a private NSButton subclass (_NSTouchBarGroupButton) with
// more bells and whistles. It doesn't use -setBezelColor: directly, but
// this gives an appearance matching the default _NSTouchBarGroupButton.
[button setBezelColor:[NSColor colorWithSRGBRed:0.168
green:0.51
blue:0.843
alpha:1.0]];
}
[button setEnabled:isButtonEnabled];
[button setTag:static_cast<int>(type)];
[item setView:button];
return item;
}
// NSTouchBarProvider protocol implementation (via NSResponder category).
- (NSTouchBar*)makeTouchBar {
if (!_bridge)
return nil;
bool buttonsExist = false;
_bridge->host()->GetDoDialogButtonsExist(&buttonsExist);
if (!buttonsExist)
return nil;
NSTouchBar* bar = [[NSTouchBar alloc] init];
[bar setDelegate:self];
// Use a group rather than individual items so they can be centered together.
[bar setDefaultItemIdentifiers:@[ kTouchBarDialogButtonsGroupId ]];
// Setting the group as principal will center it in the TouchBar.
[bar setPrincipalItemIdentifier:kTouchBarDialogButtonsGroupId];
return bar;
}
@end