Chromium Code Reviews| Index: chrome/browser/ui/cocoa/extensions/device_permissions_view_controller.mm |
| diff --git a/chrome/browser/ui/cocoa/extensions/device_permissions_view_controller.mm b/chrome/browser/ui/cocoa/extensions/device_permissions_view_controller.mm |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..8dcf4aa45a047c202417219839fdeaef2faa2dc3 |
| --- /dev/null |
| +++ b/chrome/browser/ui/cocoa/extensions/device_permissions_view_controller.mm |
| @@ -0,0 +1,83 @@ |
| +// Copyright (c) 2014 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#import "base/mac/bundle_locations.h" |
| +#include "base/strings/sys_string_conversions.h" |
| +#import "chrome/browser/ui/cocoa/extensions/device_permissions_view_controller.h" |
| +#include "chrome/grit/generated_resources.h" |
| +#include "device/usb/usb_device.h" |
| +#import "ui/base/l10n/l10n_util_mac.h" |
| + |
| +using extensions::DevicePermissionsPrompt; |
| + |
| +@interface DevicePermissionsViewController () |
| + |
| +@end |
|
Avi (use Gerrit)
2014/10/15 01:57:47
You don't need a class extension if you have nothi
Reilly Grant (use Gerrit)
2014/10/15 19:15:33
Oops. I put that there in case I needed it.
|
| + |
| +@implementation DevicePermissionsViewController |
| + |
| +- (id)initWithDelegate:(DevicePermissionsPrompt::Delegate*)delegate |
| + prompt:(scoped_refptr<DevicePermissionsPrompt::Prompt>)prompt { |
| + if ((self = [super initWithNibName:@"DevicePermissionsPrompt" |
| + bundle:base::mac::FrameworkBundle()])) { |
| + delegate_ = delegate; |
| + prompt_ = prompt; |
| + } |
| + return self; |
| +} |
| + |
| +- (IBAction)cancel:(id)sender { |
| + std::vector<scoped_refptr<device::UsbDevice>> empty; |
| + delegate_->UsbDevicesChosen(empty); |
| +} |
| + |
| +- (IBAction)ok:(id)sender { |
| + __block std::vector<scoped_refptr<device::UsbDevice>> devices; |
| + [[tableView_ selectedRowIndexes] |
| + enumerateIndexesUsingBlock:^void(NSUInteger index, BOOL* stop) { |
|
Avi (use Gerrit)
2014/10/15 01:57:47
Drop the "void"; you shouldn't need to explicitly
Reilly Grant (use Gerrit)
2014/10/15 19:15:33
Done.
|
| + prompt_->GrantDevicePermission(index); |
| + devices.push_back(prompt_->GetDevice(index)); |
| + }]; |
| + delegate_->UsbDevicesChosen(devices); |
| +} |
| + |
| +- (void)devicesChanged { |
| + [tableView_ reloadData]; |
| +} |
| + |
| +- (void)awakeFromNib { |
| + [titleField_ setStringValue:base::SysUTF16ToNSString(prompt_->GetHeading())]; |
| + [promptField_ |
| + setStringValue:base::SysUTF16ToNSString(prompt_->GetPromptMessage())]; |
| + [tableView_ setAllowsMultipleSelection:prompt_->multiple()]; |
| + [[deviceNameColumn_ headerCell] |
| + setStringValue:l10n_util::GetNSString( |
| + IDS_DEVICE_PERMISSIONS_DIALOG_DEVICE_NAME_COLUMN)]; |
| + [[serialNumberColumn_ headerCell] |
| + setStringValue:l10n_util::GetNSString( |
| + IDS_DEVICE_PERMISSIONS_DIALOG_SERIAL_NUMBER_COLUMN)]; |
| + [okButton_ |
| + setTitle:l10n_util::GetNSString(IDS_DEVICE_PERMISSIONS_DIALOG_SELECT)]; |
| + [cancelButton_ setTitle:l10n_util::GetNSString(IDS_CANCEL)]; |
| +} |
| + |
| +- (NSInteger)numberOfRowsInTableView:(NSTableView*)tableView { |
| + DCHECK_EQ(tableView_, tableView); |
| + return prompt_->GetDeviceCount(); |
| +} |
| + |
| +- (id)tableView:(NSTableView*)tableView |
| + objectValueForTableColumn:(NSTableColumn*)tableColumn |
| + row:(NSInteger)rowIndex { |
| + if (tableColumn == deviceNameColumn_) { |
| + return base::SysUTF16ToNSString(prompt_->GetDeviceName(rowIndex)); |
| + } else if (tableColumn == serialNumberColumn_) { |
| + return base::SysUTF16ToNSString(prompt_->GetDeviceSerialNumber(rowIndex)); |
| + } else { |
| + NOTREACHED(); |
| + return @""; |
| + } |
| +} |
| + |
| +@end |