Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 |
| OLD | NEW |