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

Side by Side Diff: chrome/browser/android/dom_distiller/feedback_reporter_android.cc

Issue 208263010: Fix a problem that FeedbackReportingView is stacked infinitely whenever navigating to chrome-distil… (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 9 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 unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/android/dom_distiller/feedback_reporter_android.h" 5 #include "chrome/browser/android/dom_distiller/feedback_reporter_android.h"
6 6
7 #include "base/android/jni_android.h" 7 #include "base/android/jni_android.h"
8 #include "base/android/jni_string.h"
9 #include "base/command_line.h" 8 #include "base/command_line.h"
10 #include "chrome/common/chrome_switches.h" 9 #include "chrome/common/chrome_switches.h"
11 #include "chrome/common/url_constants.h" 10 #include "chrome/common/url_constants.h"
12 #include "components/dom_distiller/core/feedback_reporter.h" 11 #include "components/dom_distiller/core/feedback_reporter.h"
13 #include "content/public/browser/navigation_details.h" 12 #include "content/public/browser/navigation_details.h"
14 #include "content/public/browser/navigation_entry.h" 13 #include "content/public/browser/navigation_entry.h"
15 #include "content/public/browser/web_contents_observer.h" 14 #include "content/public/browser/web_contents_observer.h"
16 #include "content/public/common/frame_navigate_params.h" 15 #include "content/public/common/frame_navigate_params.h"
17 #include "jni/FeedbackReporter_jni.h" 16 #include "jni/FeedbackReporter_jni.h"
18 #include "url/gurl.h" 17 #include "url/gurl.h"
19 18
20 using base::android::ConvertJavaStringToUTF8;
21 using base::android::ConvertUTF8ToJavaString;
22
23 namespace dom_distiller { 19 namespace dom_distiller {
24 20
25 namespace android { 21 namespace android {
26 22
27 // static 23 // static
28 jboolean IsEnabled(JNIEnv* env, jclass clazz) { 24 jboolean IsEnabled(JNIEnv* env, jclass clazz) {
29 return CommandLine::ForCurrentProcess()->HasSwitch( 25 return CommandLine::ForCurrentProcess()->HasSwitch(
30 switches::kEnableDomDistiller); 26 switches::kEnableDomDistiller);
31 } 27 }
32 28
33 // static 29 // static
34 void ReportQuality(JNIEnv* env, jclass clazz, jboolean j_good) { 30 void ReportQuality(JNIEnv* env, jclass clazz, jboolean j_good) {
35 FeedbackReporter::ReportQuality(j_good); 31 FeedbackReporter::ReportQuality(j_good);
36 } 32 }
37 33
38 // static
39 jboolean IsReportableUrl(JNIEnv* env, jclass clazz, jstring j_url_str) {
40 const std::string url_str = ConvertJavaStringToUTF8(env, j_url_str);
41 const GURL url(url_str);
42 if (!url.is_valid())
43 return false;
44 return url.scheme() == chrome::kDomDistillerScheme;
45 }
46
47 FeedbackReporterAndroid::FeedbackReporterAndroid(JNIEnv* env, jobject obj) 34 FeedbackReporterAndroid::FeedbackReporterAndroid(JNIEnv* env, jobject obj)
48 : weak_java_feedback_reporter_(env, obj) {} 35 : weak_java_feedback_reporter_(env, obj) {}
49 36
50 FeedbackReporterAndroid::~FeedbackReporterAndroid() {} 37 FeedbackReporterAndroid::~FeedbackReporterAndroid() {}
51 38
52 void FeedbackReporterAndroid::Destroy(JNIEnv* env, jobject obj) { delete this; } 39 void FeedbackReporterAndroid::Destroy(JNIEnv* env, jobject obj) { delete this; }
53 40
54 void FeedbackReporterAndroid::ReplaceWebContents(JNIEnv* env, 41 void FeedbackReporterAndroid::ReplaceWebContents(JNIEnv* env,
55 jobject obj, 42 jobject obj,
56 jobject jweb_contents) { 43 jobject jweb_contents) {
57 content::WebContents* web_contents = 44 content::WebContents* web_contents =
58 content::WebContents::FromJavaWebContents(jweb_contents); 45 content::WebContents::FromJavaWebContents(jweb_contents);
59 Observe(web_contents); 46 Observe(web_contents);
60 } 47 }
61 48
62 void FeedbackReporterAndroid::DidNavigateMainFrame( 49 void FeedbackReporterAndroid::DidNavigateMainFrame(
63 const content::LoadCommittedDetails& details, 50 const content::LoadCommittedDetails& details,
64 const content::FrameNavigateParams& params) { 51 const content::FrameNavigateParams& params) {
65 JNIEnv* env = base::android::AttachCurrentThread(); 52 JNIEnv* env = base::android::AttachCurrentThread();
66 ScopedJavaLocalRef<jobject> jobj = weak_java_feedback_reporter_.get(env); 53 ScopedJavaLocalRef<jobject> jobj = weak_java_feedback_reporter_.get(env);
67 if (jobj.is_null()) 54 if (jobj.is_null())
68 return; 55 return;
69 base::android::ScopedJavaLocalRef<jstring> j_current_overlay_url_str = 56 Java_FeedbackReporter_dismissOverlay(env, jobj.obj());
70 Java_FeedbackReporter_getCurrentOverlayUrl(env, jobj.obj()); 57 GURL url = details.entry->GetURL();
71 std::string current_overlay_url_str = 58 if (url.is_valid() && url.scheme() == chrome::kDomDistillerScheme)
nyquist 2014/03/31 23:08:25 Could you merge this with the other check int comp
Sungmann Cho 2014/04/01 07:51:39 Done.
72 ConvertJavaStringToUTF8(j_current_overlay_url_str); 59 Java_FeedbackReporter_showOverlay(env, jobj.obj());
73 GURL current_overlay_url(current_overlay_url_str);
74 GURL navigation_url = details.entry->GetURL();
75 if (!current_overlay_url.is_valid() || navigation_url != current_overlay_url)
76 Java_FeedbackReporter_dismissOverlay(env, jobj.obj());
77 } 60 }
78 61
79 jlong Init(JNIEnv* env, jobject obj) { 62 jlong Init(JNIEnv* env, jobject obj) {
80 FeedbackReporterAndroid* reporter = new FeedbackReporterAndroid(env, obj); 63 FeedbackReporterAndroid* reporter = new FeedbackReporterAndroid(env, obj);
81 return reinterpret_cast<intptr_t>(reporter); 64 return reinterpret_cast<intptr_t>(reporter);
82 } 65 }
83 66
84 // static 67 // static
85 bool RegisterFeedbackReporter(JNIEnv* env) { return RegisterNativesImpl(env); } 68 bool RegisterFeedbackReporter(JNIEnv* env) { return RegisterNativesImpl(env); }
86 69
87 } // namespace android 70 } // namespace android
88 71
89 } // namespace dom_distiller 72 } // namespace dom_distiller
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698