OLD | NEW |
(Empty) | |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. |
| 4 |
| 5 #ifndef IOS_CHROME_BROWSER_UI_CONTEXT_MENU_CONTEXT_MENU_COORDINATOR_H_ |
| 6 #define IOS_CHROME_BROWSER_UI_CONTEXT_MENU_CONTEXT_MENU_COORDINATOR_H_ |
| 7 |
| 8 #import <UIKit/UIKit.h> |
| 9 |
| 10 #include "base/ios/block_types.h" |
| 11 |
| 12 namespace web { |
| 13 struct ContextMenuParams; |
| 14 } |
| 15 |
| 16 // Abstracts displaying context menus for all device form factors. Will show a |
| 17 // sheet on the phone and use a popover on a tablet. |
| 18 @interface ContextMenuCoordinator : NSObject |
| 19 |
| 20 // Whether the context menu is visible. This will be true after |-start| is |
| 21 // called until a subsequent |-stop|. |
| 22 @property(nonatomic, readonly, getter=isVisible) BOOL visible; |
| 23 |
| 24 // Initializes with details provided in |params|. Context menu will be presented |
| 25 // from |viewController|. |
| 26 - (instancetype)initWithViewController:(UIViewController*)viewController |
| 27 params:(const web::ContextMenuParams&)params; |
| 28 |
| 29 // Adds an item at the end of the menu if |visible| is false. |
| 30 - (void)addItemWithTitle:(NSString*)title action:(ProceduralBlock)action; |
| 31 |
| 32 // Displays the context menu. |
| 33 - (void)start; |
| 34 // Dismisses the context menu. Any menu items which have been added will be |
| 35 // cleared after this call. |
| 36 - (void)stop; |
| 37 |
| 38 @end |
| 39 |
| 40 #endif // IOS_CHROME_BROWSER_UI_CONTEXT_MENU_CONTEXT_MENU_COORDINATOR_H_ |
OLD | NEW |