// Copyright (c) 2011 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. #ifndef WEBKIT_GLUE_WEBMENURUNNER_MAC_H_ #define WEBKIT_GLUE_WEBMENURUNNER_MAC_H_ #import <Cocoa/Cocoa.h> #include <vector> #include "base/memory/scoped_nsobject.h" #include "webkit/glue/webmenuitem.h" // WebMenuRunner --------------------------------------------------------------- // A class for determining whether an item was selected from an HTML select // control, or if the menu was dismissed without making a selection. If a menu // item is selected, MenuDelegate is informed and sets a flag which can be // queried after the menu has finished running. @interface WebMenuRunner : NSObject { @private // The native menu control. scoped_nsobject<NSMenu> menu_; // A flag set to YES if a menu item was chosen, or NO if the menu was // dismissed without selecting an item. BOOL menuItemWasChosen_; // The index of the selected menu item. int index_; // The font size being used for the menu. CGFloat fontSize_; // Whether the menu should be displayed right-aligned. BOOL rightAligned_; } // Initializes the MenuDelegate with a list of items sent from WebKit. - (id)initWithItems:(const std::vector<WebMenuItem>&)items fontSize:(CGFloat)fontSize rightAligned:(BOOL)rightAligned; // Returns YES if an item was selected from the menu, NO if the menu was // dismissed. - (BOOL)menuItemWasChosen; // Displays and runs a native popup menu. - (void)runMenuInView:(NSView*)view withBounds:(NSRect)bounds initialIndex:(int)index; // Returns the index of selected menu item, or its initial value (-1) if no item // was selected. - (int)indexOfSelectedItem; @end // @interface WebMenuRunner namespace webkit_glue { // Helper function for users of WebMenuRunner, for manufacturing input events to // send to WebKit. If |item_chosen| is YES, we manufacture a mouse click event // that corresponds to the menu item that was selected, |selected_index|, based // on the position of the mouse click. Of |item_chosen| is NO, we create a // keyboard event that simulates an ESC (menu dismissal) action. The event is // designed to be sent to WebKit for processing by the PopupMenu class. NSEvent* EventWithMenuAction(BOOL item_chosen, int window_num, int item_height, int selected_index, NSRect menu_bounds, NSRect view_bounds); } // namespace webkit_glue #endif // WEBKIT_GLUE_WEBMENURUNNER_MAC_H_