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..e83f79e133e03c0c395c5aeb23bfc6d4628db05b 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,40 @@ |
@end |
+@interface MediaGalleriesCheckbox : NSButton { |
+ @private |
+ MediaGalleriesDialogCocoa* dialog_; |
+ MediaGalleryPrefId prefid_; |
+ base::scoped_nsobject<MenuController> menu_controller_; |
+} |
+ |
+@property(nonatomic, assign) MediaGalleriesDialogCocoa* dialog; |
+@property(nonatomic, assign) MediaGalleryPrefId prefid; |
Avi (use Gerrit)
2013/11/05 19:17:33
prefid? I'd prefer prefID, or at least prefId.
An
Greg Billock
2013/11/06 18:28:25
That sounds good. Will do.
|
+ |
+- (NSMenu*)menuForEvent:(NSEvent*)theEvent; |
+ |
+@end |
+ |
+@implementation MediaGalleriesCheckbox |
+ |
+@synthesize dialog = dialog_; |
+@synthesize prefid = prefid_; |
+ |
+- (id)initWithFrame:(NSRect)frameRect { |
+ if ((self = [super initWithFrame:frameRect])) { |
+ } |
+ 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 +326,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]); |
+ [checkbox setDialog:this]; |
+ [checkbox setPrefid:gallery.pref_id]; |
NSString* unique_id = GetUniqueIDForGallery(gallery); |
[[checkbox cell] setRepresentedObject:unique_id]; |
[[checkbox cell] setLineBreakMode:NSLineBreakByTruncatingMiddle]; |
@@ -347,6 +387,11 @@ void MediaGalleriesDialogCocoa::OnConstrainedWindowClosed( |
controller_->DialogFinished(accepted_); |
} |
+ui::MenuModel* MediaGalleriesDialogCocoa::GetContextMenuModel( |
+ MediaGalleryPrefId prefid) { |
+ return controller_->GetContextMenuModel(prefid); |
+} |
+ |
// static |
MediaGalleriesDialog* MediaGalleriesDialog::Create( |
MediaGalleriesDialogController* controller) { |