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

Unified Diff: ios/chrome/browser/reading_list/reading_list_web_state_observer.h

Issue 2378123002: Load offline page if reading list entry takes more than 1s to load. (Closed)
Patch Set: Experimental change (reviewers: do not review this PS). Created 4 years, 2 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: ios/chrome/browser/reading_list/reading_list_web_state_observer.h
diff --git a/ios/chrome/browser/reading_list/reading_list_web_state_observer.h b/ios/chrome/browser/reading_list/reading_list_web_state_observer.h
new file mode 100644
index 0000000000000000000000000000000000000000..102e1e72f83028348f9df76fe65f0dda777a0bf0
--- /dev/null
+++ b/ios/chrome/browser/reading_list/reading_list_web_state_observer.h
@@ -0,0 +1,54 @@
+// Copyright 2016 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 IOS_CHROME_BROWSER_READING_LIST_READING_LIST_WEB_STATE_OBSERVER_H_
+#define IOS_CHROME_BROWSER_READING_LIST_READING_LIST_WEB_STATE_OBSERVER_H_
+
+#include "base/macros.h"
+#include "base/timer/timer.h"
+#include "ios/web/public/web_state/web_state_observer.h"
+#include "ios/web/public/web_state/web_state_user_data.h"
+
+class BrowserState;
+class ReadingListModel;
+
+// Observes the loading of pages coming from the reading list and determines
+// whether and loading an offline version of the page is needed.
+class ReadingListWebStateObserver
+ : public web::WebStateUserData<ReadingListWebStateObserver>,
+ public web::WebStateObserver {
+ public:
+ static void CreateForWebState(web::WebState* web_state,
+ web::BrowserState* browser_state);
sdefresne 2016/10/04 13:26:46 You should pass a ios::ChromeBrowserState, only co
+
+ ~ReadingListWebStateObserver() override;
+
+ private:
+ explicit ReadingListWebStateObserver(web::WebState* web_state,
sdefresne 2016/10/04 13:26:46 "explicit" is for constructor with one parameter o
+ web::BrowserState* browser_state);
+ friend class WebStateUserData<ReadingListWebStateObserver>;
+
+ // WebContentsObserver implementation.
+ void NavigationItemChanged() override;
+ void NavigationItemCommitted(
+ const web::LoadCommittedDetails& load_details) override;
+ void DidStartLoading() override;
+ void DidStopLoading() override;
+ void PageLoaded(
+ web::PageLoadCompletionStatus load_completion_status) override;
+ void WebStateDestroyed() override;
+
+ private:
+ // Heuristically determine if the reading list entry is loading quickly.
+ // If it doesn't load quickly, tries to load an offline version of the page.
+ void VerifyIfReadingListEntryStartedLoading();
+
+ web::WebState* web_state_;
+ ReadingListModel* reading_list_model_;
+ std::unique_ptr<base::Timer> timer_;
+
+ DISALLOW_COPY_AND_ASSIGN(ReadingListWebStateObserver);
+};
+
+#endif // IOS_CHROME_BROWSER_READING_LIST_READING_LIST_WEB_STATE_OBSERVER_H_

Powered by Google App Engine
This is Rietveld 408576698