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

Unified Diff: ios/chrome/browser/ui/reading_list/offline_page_native_content.mm

Issue 2589583003: Upstream Chrome on iOS source code [7/11]. (Closed)
Patch Set: Created 4 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: ios/chrome/browser/ui/reading_list/offline_page_native_content.mm
diff --git a/ios/chrome/browser/ui/reading_list/offline_page_native_content.mm b/ios/chrome/browser/ui/reading_list/offline_page_native_content.mm
new file mode 100644
index 0000000000000000000000000000000000000000..90454c15ab4c6c570898fd7bcbc79058a0b4f49e
--- /dev/null
+++ b/ios/chrome/browser/ui/reading_list/offline_page_native_content.mm
@@ -0,0 +1,82 @@
+// 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.
+
+#import "ios/chrome/browser/ui/reading_list/offline_page_native_content.h"
+
+#include "base/files/file_path.h"
+#include "base/logging.h"
+#include "components/reading_list/core/reading_list_switches.h"
+#include "components/reading_list/ios/reading_list_model.h"
+#include "ios/chrome/browser/browser_state/chrome_browser_state.h"
+#include "ios/chrome/browser/reading_list/offline_url_utils.h"
+#include "ios/chrome/browser/reading_list/reading_list_entry_loading_util.h"
+#include "ios/chrome/browser/reading_list/reading_list_model_factory.h"
+#import "ios/chrome/browser/ui/static_content/static_html_view_controller.h"
+#include "ios/web/public/browser_state.h"
+#include "net/base/network_change_notifier.h"
+
+#if !defined(__has_feature) || !__has_feature(objc_arc)
+#error "This file requires ARC support."
+#endif
+
+#pragma mark -
+#pragma mark Public
+
+@implementation OfflinePageNativeContent {
+ // The virtual URL that will be displayed to the user.
+ GURL _virtualURL;
+
+ // The Reading list model needed to reload the entry.
+ ReadingListModel* _model;
+
+ // The WebState of the current tab.
+ web::WebState* _webState;
+}
+
+- (instancetype)initWithLoader:(id<UrlLoader>)loader
+ browserState:(web::BrowserState*)browserState
+ webState:(web::WebState*)webState
+ URL:(const GURL&)URL {
+ DCHECK(loader);
+ DCHECK(browserState);
+ DCHECK(URL.is_valid());
+
+ if (reading_list::switches::IsReadingListEnabled()) {
+ _model = ReadingListModelFactory::GetForBrowserState(
+ ios::ChromeBrowserState::FromBrowserState(browserState));
+ }
+ _webState = webState;
+ GURL resourcesRoot;
+ GURL fileURL = reading_list::FileURLForDistilledURL(
+ URL, browserState->GetStatePath(), &resourcesRoot);
+
+ StaticHtmlViewController* HTMLViewController =
+ [[StaticHtmlViewController alloc] initWithFileURL:fileURL
+ allowingReadAccessToURL:resourcesRoot
+ browserState:browserState];
+ _virtualURL = reading_list::VirtualURLForDistilledURL(URL);
+
+ return [super initWithLoader:loader
+ staticHTMLViewController:HTMLViewController
+ URL:URL];
+}
+
+- (GURL)virtualURL {
+ return _virtualURL;
+}
+
+- (void)reload {
+ if (!_model || net::NetworkChangeNotifier::IsOffline()) {
+ [super reload];
+ return;
+ }
+ const ReadingListEntry* entry = _model->GetEntryByURL([self virtualURL]);
+ if (entry) {
+ reading_list::LoadReadingListEntry(*entry, _model, _webState);
+ } else {
+ [super reload];
+ }
+}
+
+@end

Powered by Google App Engine
This is Rietveld 408576698