summaryrefslogtreecommitdiffstats
path: root/chrome/browser/autofill/autofill_infobar_delegate.cc
diff options
context:
space:
mode:
authorjhawkins@chromium.org <jhawkins@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-28 19:51:21 +0000
committerjhawkins@chromium.org <jhawkins@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-28 19:51:21 +0000
commit21674df8085ee01ca91bbd4fe41ee1ea240a0cda (patch)
tree39462aa48bef10131eb36c22b38e9566336438f2 /chrome/browser/autofill/autofill_infobar_delegate.cc
parent8b160034c47761a7cefd93019d0c45b9f7911be7 (diff)
downloadchromium_src-21674df8085ee01ca91bbd4fe41ee1ea240a0cda.zip
chromium_src-21674df8085ee01ca91bbd4fe41ee1ea240a0cda.tar.gz
chromium_src-21674df8085ee01ca91bbd4fe41ee1ea240a0cda.tar.bz2
Add initial implementation of AutoFill++. This implementation is hidden behind a switch, --enable-new-autofill. So far, we only pop up an infobar asking the user if he'd like to save the form information. I've added a rudimentary icon for the infobar, pulled from the mocks, so we'll probably want a blessed version of this icon at some point.
BUG=18201 TEST=none Review URL: http://codereview.chromium.org/339030 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@30378 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/autofill/autofill_infobar_delegate.cc')
-rw-r--r--chrome/browser/autofill/autofill_infobar_delegate.cc76
1 files changed, 76 insertions, 0 deletions
diff --git a/chrome/browser/autofill/autofill_infobar_delegate.cc b/chrome/browser/autofill/autofill_infobar_delegate.cc
new file mode 100644
index 0000000..9333b3a
--- /dev/null
+++ b/chrome/browser/autofill/autofill_infobar_delegate.cc
@@ -0,0 +1,76 @@
+// Copyright (c) 2009 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.
+
+#include "chrome/browser/autofill/autofill_infobar_delegate.h"
+
+#include "app/l10n_util.h"
+#include "app/resource_bundle.h"
+#include "chrome/browser/autofill/autofill_manager.h"
+#include "chrome/browser/tab_contents/tab_contents.h"
+#include "grit/chromium_strings.h"
+#include "grit/generated_resources.h"
+#include "grit/theme_resources.h"
+#include "third_party/skia/include/core/SkBitmap.h"
+
+AutoFillInfoBarDelegate::AutoFillInfoBarDelegate(TabContents* tab_contents,
+ AutoFillManager* host)
+ : ConfirmInfoBarDelegate(tab_contents),
+ host_(host) {
+ if (tab_contents)
+ tab_contents->AddInfoBar(this);
+}
+
+AutoFillInfoBarDelegate::~AutoFillInfoBarDelegate() {
+}
+
+bool AutoFillInfoBarDelegate::ShouldExpire(
+ const NavigationController::LoadCommittedDetails& details) const {
+ // The user has submitted a form, causing the page to navigate elsewhere. We
+ // don't want the infobar to be expired at this point, because the user won't
+ // get a chance to answer the question.
+ return false;
+}
+
+void AutoFillInfoBarDelegate::InfoBarClosed() {
+ Cancel();
+ // This will delete us.
+ ConfirmInfoBarDelegate::InfoBarClosed();
+}
+
+std::wstring AutoFillInfoBarDelegate::GetMessageText() const {
+ return l10n_util::GetString(IDS_AUTOFILL_INFOBAR_TEXT);
+}
+
+SkBitmap* AutoFillInfoBarDelegate::GetIcon() const {
+ return ResourceBundle::GetSharedInstance().GetBitmapNamed(
+ IDR_INFOBAR_AUTOFILL);
+}
+
+int AutoFillInfoBarDelegate::GetButtons() const {
+ return BUTTON_OK | BUTTON_CANCEL;
+}
+
+std::wstring AutoFillInfoBarDelegate::GetButtonLabel(
+ ConfirmInfoBarDelegate::InfoBarButton button) const {
+ if (button == BUTTON_OK)
+ return l10n_util::GetString(IDS_AUTOFILL_INFOBAR_ACCEPT);
+
+ return l10n_util::GetString(IDS_AUTOFILL_INFOBAR_DENY);
+}
+
+bool AutoFillInfoBarDelegate::Accept() {
+ if (host_) {
+ host_->SaveFormData();
+ host_ = NULL;
+ }
+ return true;
+}
+
+bool AutoFillInfoBarDelegate::Cancel() {
+ if (host_) {
+ host_->Reset();
+ host_ = NULL;
+ }
+ return true;
+}