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

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: total different approach 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
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..76884c9b5af963b4c1d5a734e3f4a31de11ff5a3
--- /dev/null
+++ b/chrome/browser/ui/webui/uber/uber_ui.cc
@@ -0,0 +1,83 @@
+// 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 "base/stl_util.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']");
arv (Not doing code reviews) 2011/12/09 06:47:44 Why xpath and not CSS selector?
+ sub_uis_.push_back(options);
+}
+
+UberUI::~UberUI() {
+ STLDeleteElements(&sub_uis_);
James Hawkins 2011/12/10 03:03:13 Use a ScopedVector.
Evan Stade 2011/12/13 00:15:27 Done.
+}
+
+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() OVERRIDE {
+ 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) {
+ for (size_t i = 0; i < sub_uis_.size(); i++) {
+ sub_uis_[i]->OnWebUISend(source_url, message, args);
+ }
+
+ ChromeWebUI::OnWebUISend(source_url, message, args);
+}
+
+/*
James Hawkins 2011/12/10 03:03:13 Remove?
Evan Stade 2011/12/13 00:15:27 Done.
+void UberUI::CallJavascriptFunction(const std::string& function_name,
+ const base::Value& arg) {
+ base::StringValue id_value(function_name);
+ WebUI::CallJavascriptFunction("postFunction", id_value, arg);
+}
+*/

Powered by Google App Engine
This is Rietveld 408576698