Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2823)

Unified Diff: chrome/browser/ui/cocoa/extensions/media_galleries_dialog_cocoa.mm

Issue 46503002: [MediaGalleries] Context menu for Mac media galleries dialog. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Take properties off checkbox subclass Created 7 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/browser/ui/cocoa/extensions/media_galleries_dialog_cocoa.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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..64985bfcd987b50e38f72ba874b790a01c902465 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;
+
+@end
+
+@implementation MediaGalleriesCheckbox
+
+- (id)initWithFrame:(NSRect)frameRect
+ dialog:(MediaGalleriesDialogCocoa*)dialog
+ prefId:(MediaGalleryPrefId)prefId {
+ if ((self = [super initWithFrame:frameRect])) {
+ }
+ dialog_ = dialog;
+ prefId_ = prefId;
Avi (use Gerrit) 2013/11/06 18:49:26 These assignments go in the braces (otherwise you'
Greg Billock 2013/11/06 21:59:24 Done.
+ 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) {
« no previous file with comments | « chrome/browser/ui/cocoa/extensions/media_galleries_dialog_cocoa.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698