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

Side by Side Diff: chrome/browser/ui/search/instant_page.h

Issue 2146953002: Rename InstantPage to InstantTab. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@instant-page
Patch Set: Created 4 years, 5 months 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 unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2013 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 CHROME_BROWSER_UI_SEARCH_INSTANT_PAGE_H_
6 #define CHROME_BROWSER_UI_SEARCH_INSTANT_PAGE_H_
7
8 #include "base/compiler_specific.h"
9 #include "base/gtest_prod_util.h"
10 #include "base/macros.h"
11 #include "chrome/browser/ui/search/search_model_observer.h"
12 #include "content/public/browser/web_contents_observer.h"
13 #include "ui/base/page_transition_types.h"
14
15 class GURL;
16
17 namespace content {
18 class RenderFrameHost;
19 class WebContents;
20 }
21
22 // InstantPage is used to exchange messages with a page that implements the
23 // Instant/Embedded Search API (http://dev.chromium.org/embeddedsearch).
24 class InstantPage : public content::WebContentsObserver,
25 public SearchModelObserver {
26 public:
27 // InstantPage calls its delegate in response to messages received from the
28 // page. Each method is called with the |contents| corresponding to the page
29 // we are observing.
30 class Delegate {
31 public:
32 // Called upon determination of Instant API support. Either in response to
33 // the page loading or because we received some other message.
34 virtual void InstantSupportDetermined(const content::WebContents* contents,
35 bool supports_instant) = 0;
36
37 // Called when the page is about to navigate to |url|.
38 virtual void InstantPageAboutToNavigateMainFrame(
39 const content::WebContents* contents,
40 const GURL& url) = 0;
41
42 protected:
43 virtual ~Delegate();
44 };
45
46 explicit InstantPage(Delegate* delegate);
47
48 ~InstantPage() override;
49
50 // Sets |web_contents| as the page to communicate with. |web_contents| may be
51 // NULL, which effectively stops all communication.
52 void Init(content::WebContents* web_contents);
53
54 // Returns true if the page is known to support the Instant API. This starts
55 // out false, and is set to true whenever we get any message from the page.
56 // Once true, it never becomes false (the page isn't expected to drop API
57 // support suddenly).
58 bool supports_instant() const;
59
60 // Returns true if the page is the local NTP (i.e. its URL is
61 // chrome::kChromeSearchLocalNTPURL).
62 bool IsLocal() const;
63
64 private:
65 FRIEND_TEST_ALL_PREFIXES(InstantPageTest, IsLocal);
66 FRIEND_TEST_ALL_PREFIXES(InstantPageTest,
67 DetermineIfPageSupportsInstant_Local);
68 FRIEND_TEST_ALL_PREFIXES(InstantPageTest,
69 DetermineIfPageSupportsInstant_NonLocal);
70 FRIEND_TEST_ALL_PREFIXES(InstantPageTest,
71 PageURLDoesntBelongToInstantRenderer);
72 FRIEND_TEST_ALL_PREFIXES(InstantPageTest, PageSupportsInstant);
73
74 // Overridden from content::WebContentsObserver:
75 void DidCommitProvisionalLoadForFrame(
76 content::RenderFrameHost* render_frame_host,
77 const GURL& url,
78 ui::PageTransition transition_type) override;
79
80 // Overridden from SearchModelObserver:
81 void ModelChanged(const SearchModel::State& old_state,
82 const SearchModel::State& new_state) override;
83
84 // Update the status of Instant support.
85 void InstantSupportDetermined(bool supports_instant);
86
87 void ClearContents();
88
89 Delegate* const delegate_;
90
91 DISALLOW_COPY_AND_ASSIGN(InstantPage);
92 };
93
94 #endif // CHROME_BROWSER_UI_SEARCH_INSTANT_PAGE_H_
OLDNEW
« no previous file with comments | « chrome/browser/ui/search/instant_controller.cc ('k') | chrome/browser/ui/search/instant_page.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698