blob: 8f4d017cc0d98901fb154aad8003f4cdf1916d0a (
plain)
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
|
// Copyright (c) 2009 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_GTK_LOCATION_BAR_VIEW_GTK_H_
#define CHROME_BROWSER_GTK_LOCATION_BAR_VIEW_GTK_H_
#include <gtk/gtk.h>
#include <string>
#include "base/basictypes.h"
#include "base/scoped_ptr.h"
#include "chrome/browser/autocomplete/autocomplete_edit.h"
#include "chrome/browser/location_bar.h"
#include "chrome/common/owned_widget_gtk.h"
#include "chrome/common/page_transition_types.h"
#include "webkit/glue/window_open_disposition.h"
class AutocompleteEditViewGtk;
class CommandUpdater;
class Profile;
class SkBitmap;
class TabContents;
class ToolbarModel;
class LocationBarViewGtk : public AutocompleteEditController,
public LocationBar {
public:
LocationBarViewGtk(CommandUpdater* command_updater,
ToolbarModel* toolbar_model);
~LocationBarViewGtk();
void Init();
void SetProfile(Profile* profile);
// Returns the widget the caller should host. You must call Init() first.
GtkWidget* widget() { return outer_bin_.get(); }
// Updates the location bar. We also reset the bar's permanent text and
// security style, and, if |tab_for_state_restoring| is non-NULL, also
// restore saved state that the tab holds.
void Update(const TabContents* tab_for_state_restoring);
// Implement the AutocompleteEditController interface.
virtual void OnAutocompleteAccept(const GURL& url,
WindowOpenDisposition disposition,
PageTransition::Type transition,
const GURL& alternate_nav_url);
virtual void OnChanged();
virtual void OnInputInProgress(bool in_progress);
virtual SkBitmap GetFavIcon() const;
virtual std::wstring GetTitle() const;
// Implement the LocationBar interface.
virtual void ShowFirstRunBubble();
virtual std::wstring GetInputString() const;
virtual WindowOpenDisposition GetWindowOpenDisposition() const;
virtual PageTransition::Type GetPageTransition() const;
virtual void AcceptInput();
virtual void AcceptInputWithDisposition(WindowOpenDisposition);
virtual void FocusLocation();
virtual void FocusSearch();
virtual void UpdateFeedIcon();
virtual void SaveStateToContents(TabContents* contents);
private:
// The outermost widget we want to be hosted.
OwnedWidgetGtk outer_bin_;
// This is the widget you probably care about, our inner vbox (inside the
// the border) which holds the elements inside the location bar.
GtkWidget* inner_vbox_;
scoped_ptr<AutocompleteEditViewGtk> location_entry_;
Profile* profile_;
CommandUpdater* command_updater_;
ToolbarModel* toolbar_model_;
// When we get an OnAutocompleteAccept notification from the autocomplete
// edit, we save the input string so we can give it back to the browser on
// the LocationBar interface via GetInputString().
std::wstring location_input_;
// The user's desired disposition for how their input should be opened
WindowOpenDisposition disposition_;
// The transition type to use for the navigation
PageTransition::Type transition_;
DISALLOW_COPY_AND_ASSIGN(LocationBarViewGtk);
};
#endif // CHROME_BROWSER_GTK_LOCATION_BAR_VIEW_GTK_H_
|