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

Unified Diff: chrome/renderer/net/net_error_page_controller.h

Issue 207553008: Surface button for loading stale cache copy on net error page. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Incorporated comments. Created 6 years, 8 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 side-by-side diff with in-line comments
Download patch
Index: chrome/renderer/net/net_error_page_controller.h
diff --git a/chrome/renderer/net/net_error_page_controller.h b/chrome/renderer/net/net_error_page_controller.h
new file mode 100644
index 0000000000000000000000000000000000000000..f3d4d166f1b76db2c73b945720ea8647032c1210
--- /dev/null
+++ b/chrome/renderer/net/net_error_page_controller.h
@@ -0,0 +1,59 @@
+// Copyright 2014 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_RENDERER_NET_NET_ERROR_PAGE_CONTROLLER_H_
+#define CHROME_RENDERER_NET_NET_ERROR_PAGE_CONTROLLER_H_
+
+#include "base/basictypes.h"
mmenke 2014/04/11 19:42:32 Use macros.h instead (basictypes includes DISALLOW
Randy Smith (Not in Mondays) 2014/04/14 22:02:13 Done.
+#include "content/public/renderer/render_frame_observer.h"
+#include "gin/wrappable.h"
+#include "url/gurl.h"
mmenke 2014/04/11 19:42:32 Not used.
Randy Smith (Not in Mondays) 2014/04/14 22:02:13 Done.
+
+// NetErrorPageController class:
mmenke 2014/04/11 19:42:32 optional: Think this is a little redundant. Sugg
Randy Smith (Not in Mondays) 2014/04/14 22:02:13 Done.
+//
+// This class makes cache loading operations available to the
+// error page loaded by NetErrorHelper. It is bound to the javascript
mmenke 2014/04/11 19:42:32 nit: Javascript.
Randy Smith (Not in Mondays) 2014/04/14 22:02:13 Done (JavaScript).
+// window.errorCacheLoad object.
mmenke 2014/04/11 19:42:32 These generally go right above the class, not the
mmenke 2014/04/11 19:42:32 The window.helperFunctions object, now. window.er
Randy Smith (Not in Mondays) 2014/04/14 22:02:13 Done.
Randy Smith (Not in Mondays) 2014/04/14 22:02:13 Done.
+
+class GURL;
mmenke 2014/04/11 19:42:32 Not used.
Randy Smith (Not in Mondays) 2014/04/14 22:02:13 Done.
+
+namespace content {
+class RenderFrame;
+}
+
+// Error page functions called from Javascript.
+class NetErrorPageController
+ : public gin::Wrappable<NetErrorPageController>,
+ public content::RenderFrameObserver {
jochen (gone - plz use gerrit) 2014/04/14 07:32:35 why do you derive from RFO?
jochen (gone - plz use gerrit) 2014/04/14 13:11:53 ah, I see that you're using RenderFrameObserver::r
mmenke 2014/04/14 14:05:46 Yea, we're using the OnDestruct method, so we don'
+ public:
+ static gin::WrapperInfo kWrapperInfo;
+
+ static void Install(content::RenderFrame* render_frame);
+
+ private:
+ explicit NetErrorPageController(content::RenderFrame* render_frame);
+ virtual ~NetErrorPageController();
+
+ // Execute a "Load Stale" button click.
+ bool LoadStaleButtonClick();
+
+ // Execute a "Reload" button click.
+ bool ReloadButtonClick();
+
+ // Execute a "More" button click.
+ bool MoreButtonClick();
+
+ // gin::WrappableBase
+ virtual gin::ObjectTemplateBuilder GetObjectTemplateBuilder(
+ v8::Isolate* isolate) OVERRIDE;
+
+ // RenderFrameObserver. Overridden to avoid being destroyed when RenderFrame
+ // goes away; NetErrorPageController objects are owned by the JS
+ // garbage collector.
+ virtual void OnDestruct() OVERRIDE;
+
+ DISALLOW_COPY_AND_ASSIGN(NetErrorPageController);
+};
+
+#endif // CHROME_RENDERER_NET_NET_ERROR_PAGE_CONTROLLER_H_

Powered by Google App Engine
This is Rietveld 408576698