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

Side by Side Diff: android_webview/native/aw_contents.cc

Issue 15097004: Enable Autocomplete feature for chromium webview (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@setSaveFormData2
Patch Set: enable autocomplete independent of autofill. Created 7 years, 6 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 2012 The Chromium Authors. All rights reserved. 1 // Copyright 2012 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 "android_webview/native/aw_contents.h" 5 #include "android_webview/native/aw_contents.h"
6 6
7 #include "android_webview/browser/aw_browser_context.h" 7 #include "android_webview/browser/aw_browser_context.h"
8 #include "android_webview/browser/aw_browser_main_parts.h" 8 #include "android_webview/browser/aw_browser_main_parts.h"
9 #include "android_webview/browser/browser_view_renderer_impl.h" 9 #include "android_webview/browser/browser_view_renderer_impl.h"
10 #include "android_webview/browser/gpu_memory_buffer_impl.h" 10 #include "android_webview/browser/gpu_memory_buffer_impl.h"
(...skipping 136 matching lines...) Expand 10 before | Expand all | Expand 10 after
147 icon_helper_->SetListener(this); 147 icon_helper_->SetListener(this);
148 web_contents_->SetUserData(kAwContentsUserDataKey, 148 web_contents_->SetUserData(kAwContentsUserDataKey,
149 new AwContentsUserData(this)); 149 new AwContentsUserData(this));
150 AwContentsClientBridgeBase::Associate(web_contents_.get(), 150 AwContentsClientBridgeBase::Associate(web_contents_.get(),
151 contents_client_bridge_.get()); 151 contents_client_bridge_.get());
152 web_contents_->SetDelegate(web_contents_delegate_.get()); 152 web_contents_->SetDelegate(web_contents_delegate_.get());
153 render_view_host_ext_.reset( 153 render_view_host_ext_.reset(
154 new AwRenderViewHostExt(this, web_contents_.get())); 154 new AwRenderViewHostExt(this, web_contents_.get()));
155 155
156 AwAutofillManagerDelegate* autofill_manager_delegate = 156 AwAutofillManagerDelegate* autofill_manager_delegate =
157 AwBrowserContext::FromWebContents(web_contents_.get())-> 157 AwAutofillManagerDelegate::FromWebContents(web_contents_.get());
158 AutofillManagerDelegate();
159 if (autofill_manager_delegate) 158 if (autofill_manager_delegate)
160 InitAutofillIfNecessary(autofill_manager_delegate->GetSaveFormData()); 159 InitAutofillIfNecessary(autofill_manager_delegate->GetSaveFormData());
161 } 160 }
162 161
163 void AwContents::SetSaveFormData(bool enabled) { 162 void AwContents::SetSaveFormData(bool enabled) {
164 InitAutofillIfNecessary(enabled); 163 InitAutofillIfNecessary(enabled);
165 // We need to check for the existence, since autofill_manager_delegate 164 AwAutofillManagerDelegate::FromWebContents(web_contents_.get())->
166 // may not be created when the setting is false. 165 SetSaveFormData(enabled);
167 if (AutofillManager::FromWebContents(web_contents_.get())) {
168 AwAutofillManagerDelegate* autofill_manager_delegate =
169 AwBrowserContext::FromWebContents(web_contents_.get())->
170 AutofillManagerDelegate();
171 autofill_manager_delegate->SetSaveFormData(enabled);
172 }
173 } 166 }
174 167
175 void AwContents::InitAutofillIfNecessary(bool enabled) { 168 void AwContents::InitAutofillIfNecessary(bool enabled) {
176 // Do not initialize if the feature is not enabled. 169 // Do not initialize if the feature is not enabled.
177 if (!enabled) 170 if (!enabled)
178 return; 171 return;
179 // Check if the autofill manager already exists. 172
180 content::WebContents* web_contents = web_contents_.get(); 173 content::WebContents* web_contents = web_contents_.get();
181 if (AutofillManager::FromWebContents(web_contents)) 174 if (AutofillManager::FromWebContents(web_contents))
182 return; 175 return;
183 176
177 AwBrowserContext::FromWebContents(web_contents)->
178 CreateUserPrefServiceIfNecessary();
179
180 AwAutofillManagerDelegate::CreateForWebContents(web_contents);
181
184 AutofillManager::CreateForWebContentsAndDelegate( 182 AutofillManager::CreateForWebContentsAndDelegate(
185 web_contents, 183 web_contents,
186 AwBrowserContext::FromWebContents(web_contents)-> 184 AwAutofillManagerDelegate::FromWebContents(web_contents),
187 CreateAutofillManagerDelegate(enabled),
188 l10n_util::GetDefaultLocale(), 185 l10n_util::GetDefaultLocale(),
189 AutofillManager::DISABLE_AUTOFILL_DOWNLOAD_MANAGER); 186 AutofillManager::DISABLE_AUTOFILL_DOWNLOAD_MANAGER);
190 AutofillManager* autofill_manager = 187 AutofillManager* autofill_manager =
191 AutofillManager::FromWebContents(web_contents); 188 AutofillManager::FromWebContents(web_contents);
192 AutofillExternalDelegate::CreateForWebContentsAndManager( 189 AutofillExternalDelegate::CreateForWebContentsAndManager(
193 web_contents, 190 web_contents,
194 autofill_manager); 191 autofill_manager);
195 autofill_manager->SetExternalDelegate( 192 autofill_manager->SetExternalDelegate(
196 AutofillExternalDelegate::FromWebContents(web_contents)); 193 AutofillExternalDelegate::FromWebContents(web_contents));
197 } 194 }
(...skipping 508 matching lines...) Expand 10 before | Expand all | Expand 10 after
706 return browser_view_renderer_->CapturePicture(); 703 return browser_view_renderer_->CapturePicture();
707 } 704 }
708 705
709 void AwContents::EnableOnNewPicture(JNIEnv* env, 706 void AwContents::EnableOnNewPicture(JNIEnv* env,
710 jobject obj, 707 jobject obj,
711 jboolean enabled) { 708 jboolean enabled) {
712 browser_view_renderer_->EnableOnNewPicture(enabled); 709 browser_view_renderer_->EnableOnNewPicture(enabled);
713 } 710 }
714 711
715 } // namespace android_webview 712 } // namespace android_webview
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698