1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
|
// Copyright (c) 2006-2008 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 CHROME_BROWSER_BOOKMARKS_BOOKMARK_CONTEXT_MENU_H_
#define CHROME_BROWSER_BOOKMARKS_BOOKMARK_CONTEXT_MENU_H_
#include <vector>
#include "base/basictypes.h"
#include "base/gfx/native_widget_types.h"
#include "chrome/browser/bookmarks/bookmark_model.h"
// TODO(port): Port this file.
#if defined(OS_WIN)
#include "views/controls/menu/chrome_menu.h"
#elif defined(OS_LINUX)
#include "chrome/browser/gtk/menu_gtk.h"
#else
#include "chrome/common/temp_scaffolding_stubs.h"
#endif
class Browser;
class PageNavigator;
// BookmarkContextMenu manages the context menu shown for the
// bookmark bar, items on the bookmark bar, submenus of the bookmark bar and
// the bookmark manager.
class BookmarkContextMenu : public BookmarkModelObserver,
#if defined(OS_WIN)
public views::MenuDelegate
#elif defined(OS_LINUX)
public MenuGtk::Delegate
#endif
{
public:
// Used to configure what the context menu shows.
enum ConfigurationType {
BOOKMARK_BAR,
BOOKMARK_MANAGER_TABLE,
// Used when the source is the table in the bookmark manager and the table
// is showing recently bookmarked or searched.
BOOKMARK_MANAGER_TABLE_OTHER,
BOOKMARK_MANAGER_TREE,
BOOKMARK_MANAGER_ORGANIZE_MENU,
// Used when the source is the bookmark manager and the table is showing
// recently bookmarked or searched.
BOOKMARK_MANAGER_ORGANIZE_MENU_OTHER
};
// Creates the bookmark context menu.
// |profile| is used for opening urls as well as enabling 'open incognito'.
// |browser| is used to determine the PageNavigator and may be null.
// |navigator| is used if |browser| is null, and is provided for testing.
// |parent| is the parent for newly created nodes if |selection| is empty.
// |selection| is the nodes the context menu operates on and may be empty.
// |configuration| determines which items to show.
BookmarkContextMenu(gfx::NativeWindow hwnd,
Profile* profile,
Browser* browser,
PageNavigator* navigator,
BookmarkNode* parent,
const std::vector<BookmarkNode*>& selection,
ConfigurationType configuration);
virtual ~BookmarkContextMenu();
#if defined(OS_WIN)
// Shows the menu at the specified place.
void RunMenuAt(int x, int y);
// Returns the menu.
views::MenuItemView* menu() const { return menu_.get(); }
#elif defined(OS_LINUX)
// Pops up this menu. This call doesn't block.
void PopupAsContext(guint32 event_time);
#endif
// Menu::Delegate / MenuGtk::Delegate methods.
virtual void ExecuteCommand(int id);
virtual bool IsItemChecked(int id) const;
virtual bool IsCommandEnabled(int id) const;
private:
// BookmarkModelObserver method. Any change to the model results in closing
// the menu.
virtual void Loaded(BookmarkModel* model) {}
virtual void BookmarkModelBeingDeleted(BookmarkModel* model);
virtual void BookmarkNodeMoved(BookmarkModel* model,
BookmarkNode* old_parent,
int old_index,
BookmarkNode* new_parent,
int new_index);
virtual void BookmarkNodeAdded(BookmarkModel* model,
BookmarkNode* parent,
int index);
virtual void BookmarkNodeRemoved(BookmarkModel* model,
BookmarkNode* parent,
int index,
BookmarkNode* node);
virtual void BookmarkNodeChanged(BookmarkModel* model,
BookmarkNode* node);
virtual void BookmarkNodeFavIconLoaded(BookmarkModel* model,
BookmarkNode* node) {}
virtual void BookmarkNodeChildrenReordered(BookmarkModel* model,
BookmarkNode* node);
// Invoked from the various bookmark model observer methods. Closes the menu.
void ModelChanged();
// Builds the platform specific menu object.
void CreateMenuObject();
// Adds a IDS_* style command to the menu.
void AppendItem(int id);
// Adds a IDS_* style command to the menu with a different localized string.
void AppendItem(int id, int localization_id);
// Adds a separator to the menu.
void AppendSeparator();
// Adds a checkable item to the menu.
void AppendCheckboxItem(int id);
// Removes the observer from the model and NULLs out model_.
BookmarkModel* RemoveModelObserver();
// Returns true if selection_ has at least one bookmark of type url.
bool HasURLs() const;
// Returns the parent for newly created folders/bookmarks. If selection_
// has one element and it is a folder, selection_[0] is returned, otherwise
// parent_ is returned.
BookmarkNode* GetParentForNewNodes() const;
gfx::NativeWindow wnd_;
Profile* profile_;
Browser* browser_;
PageNavigator* navigator_;
BookmarkNode* parent_;
std::vector<BookmarkNode*> selection_;
BookmarkModel* model_;
ConfigurationType configuration_;
#if defined(OS_WIN)
scoped_ptr<views::MenuItemView> menu_;
#elif defined(OS_LINUX)
scoped_ptr<MenuGtk> menu_;
#endif
DISALLOW_COPY_AND_ASSIGN(BookmarkContextMenu);
};
#endif // CHROME_BROWSER_BOOKMARKS_BOOKMARK_CONTEXT_MENU_H_
|