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

Unified Diff: chrome/browser/ui/webui/uber/uber_ui.cc

Issue 8889041: first cut at uber page (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: mac compile Created 9 years 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/browser/ui/webui/uber/uber_ui.h ('k') | chrome/chrome_browser.gypi » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/ui/webui/uber/uber_ui.cc
diff --git a/chrome/browser/ui/webui/uber/uber_ui.cc b/chrome/browser/ui/webui/uber/uber_ui.cc
new file mode 100644
index 0000000000000000000000000000000000000000..85031123c0fc361d61c3f48fbf13810256d82a6d
--- /dev/null
+++ b/chrome/browser/ui/webui/uber/uber_ui.cc
@@ -0,0 +1,75 @@
+// 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.
+
+#include "chrome/browser/ui/webui/uber/uber_ui.h"
+
+#include "chrome/browser/profiles/profile.h"
+#include "chrome/browser/ui/webui/chrome_url_data_manager.h"
+#include "chrome/browser/ui/webui/chrome_web_ui_data_source.h"
+#include "chrome/browser/ui/webui/options/options_ui.h"
+#include "chrome/common/url_constants.h"
+#include "content/browser/tab_contents/tab_contents.h"
+#include "grit/browser_resources.h"
+
+namespace {
+
+ChromeWebUIDataSource* CreateUberHTMLSource() {
+ ChromeWebUIDataSource* source =
+ new ChromeWebUIDataSource(chrome::kChromeUIUberHost);
+
+ source->set_json_path("strings.js");
+ source->add_resource_path("uber.js", IDR_UBER_JS);
+ source->set_default_resource(IDR_UBER_HTML);
+ return source;
+}
+
+} // namespace
+
+UberUI::UberUI(TabContents* contents) : ChromeWebUI(contents) {
+ Profile* profile = Profile::FromBrowserContext(contents->browser_context());
+ profile->GetChromeURLDataManager()->AddDataSource(CreateUberHTMLSource());
+
+ ChromeWebUI* options = new OptionsUI(contents);
+ options->set_frame_xpath("//iframe[@id='settings']");
+ sub_uis_.push_back(options);
+}
+
+UberUI::~UberUI() {
+}
+
+void UberUI::RenderViewCreated(RenderViewHost* render_view_host) {
+ for (size_t i = 0; i < sub_uis_.size(); i++) {
+ sub_uis_[i]->RenderViewCreated(render_view_host);
+ }
+
+ ChromeWebUI::RenderViewCreated(render_view_host);
+}
+
+void UberUI::RenderViewReused(RenderViewHost* render_view_host) {
+ for (size_t i = 0; i < sub_uis_.size(); i++) {
+ sub_uis_[i]->RenderViewReused(render_view_host);
+ }
+
+ ChromeWebUI::RenderViewReused(render_view_host);
+}
+
+void UberUI::DidBecomeActiveForReusedRenderView() {
+ for (size_t i = 0; i < sub_uis_.size(); i++) {
+ sub_uis_[i]->DidBecomeActiveForReusedRenderView();
+ }
+
+ ChromeWebUI::DidBecomeActiveForReusedRenderView();
+}
+
+void UberUI::OnWebUISend(const GURL& source_url,
+ const std::string& message,
+ const ListValue& args) {
+ // TODO(estade): This should only send the message to the appropriate
+ // subpage (if any), not all of them.
+ for (size_t i = 0; i < sub_uis_.size(); i++) {
+ sub_uis_[i]->OnWebUISend(source_url, message, args);
+ }
+
+ ChromeWebUI::OnWebUISend(source_url, message, args);
+}
« no previous file with comments | « chrome/browser/ui/webui/uber/uber_ui.h ('k') | chrome/chrome_browser.gypi » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698