Index: chrome/browser/ui/cocoa/extensions/media_galleries_dialog_cocoa.mm |
diff --git a/chrome/browser/ui/cocoa/extensions/media_galleries_dialog_cocoa.mm b/chrome/browser/ui/cocoa/extensions/media_galleries_dialog_cocoa.mm |
index edc13a173cba4cfdad52f307321bd5b057e81d12..c713ffe74df3e4cf63a3cf4e92284d496fba4d88 100644 |
--- a/chrome/browser/ui/cocoa/extensions/media_galleries_dialog_cocoa.mm |
+++ b/chrome/browser/ui/cocoa/extensions/media_galleries_dialog_cocoa.mm |
@@ -4,6 +4,7 @@ |
#include "chrome/browser/ui/cocoa/extensions/media_galleries_dialog_cocoa.h" |
+#include "base/mac/scoped_nsobject.h" |
#include "base/strings/sys_string_conversions.h" |
#include "chrome/browser/ui/chrome_style.h" |
#import "chrome/browser/ui/cocoa/constrained_window/constrained_window_alert.h" |
@@ -14,9 +15,12 @@ |
#include "content/public/browser/web_contents.h" |
#include "grit/generated_resources.h" |
#import "ui/base/cocoa/flipped_view.h" |
+#import "ui/base/cocoa/menu_controller.h" |
+#import "ui/base/models/menu_model.h" |
#include "ui/base/l10n/l10n_util.h" |
#include "ui/base/resource/resource_bundle.h" |
+// Controller for UI events on items in the media galleries dialog. |
@interface MediaGalleriesCocoaController : NSObject { |
@private |
MediaGalleriesDialogCocoa* dialog_; |
@@ -50,6 +54,38 @@ |
@end |
+@interface MediaGalleriesCheckbox : NSButton { |
+ @private |
+ MediaGalleriesDialogCocoa* dialog_; |
+ MediaGalleryPrefId prefId_; |
+ base::scoped_nsobject<MenuController> menu_controller_; |
+} |
+ |
+- (NSMenu*)menuForEvent:(NSEvent*)theEvent; |
Avi (use Gerrit)
2013/11/06 22:01:51
Now that you have a custom initializer you need to
Greg Billock
2013/11/06 22:30:18
Done.
|
+ |
+@end |
+ |
+@implementation MediaGalleriesCheckbox |
+ |
+- (id)initWithFrame:(NSRect)frameRect |
+ dialog:(MediaGalleriesDialogCocoa*)dialog |
+ prefId:(MediaGalleryPrefId)prefId { |
+ if ((self = [super initWithFrame:frameRect])) { |
+ dialog_ = dialog; |
+ prefId_ = prefId; |
+ } |
+ return self; |
+} |
+ |
+- (NSMenu*)menuForEvent:(NSEvent*)theEvent { |
+ menu_controller_.reset( |
+ [[MenuController alloc] initWithModel:dialog_->GetContextMenuModel(prefId_) |
+ useWithPopUpButtonCell:NO]); |
+ return [menu_controller_ menu]; |
+} |
+ |
+@end |
+ |
namespace { |
const CGFloat kCheckboxMargin = 10; |
@@ -288,8 +324,10 @@ void MediaGalleriesDialogCocoa::UpdateGalleryCheckbox( |
const MediaGalleryPrefInfo& gallery, |
bool permitted, |
CGFloat y_pos) { |
- base::scoped_nsobject<NSButton> checkbox( |
- [[NSButton alloc] initWithFrame:NSZeroRect]); |
+ base::scoped_nsobject<MediaGalleriesCheckbox> checkbox( |
+ [[MediaGalleriesCheckbox alloc] initWithFrame:NSZeroRect |
+ dialog:this |
+ prefId:gallery.pref_id]); |
NSString* unique_id = GetUniqueIDForGallery(gallery); |
[[checkbox cell] setRepresentedObject:unique_id]; |
[[checkbox cell] setLineBreakMode:NSLineBreakByTruncatingMiddle]; |
@@ -347,6 +385,11 @@ void MediaGalleriesDialogCocoa::OnConstrainedWindowClosed( |
controller_->DialogFinished(accepted_); |
} |
+ui::MenuModel* MediaGalleriesDialogCocoa::GetContextMenuModel( |
+ MediaGalleryPrefId prefid) { |
+ return controller_->GetContextMenuModel(prefid); |
+} |
+ |
// static |
MediaGalleriesDialog* MediaGalleriesDialog::Create( |
MediaGalleriesDialogController* controller) { |