diff options
author | jhawkins@chromium.org <jhawkins@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-28 19:51:21 +0000 |
---|---|---|
committer | jhawkins@chromium.org <jhawkins@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-28 19:51:21 +0000 |
commit | 21674df8085ee01ca91bbd4fe41ee1ea240a0cda (patch) | |
tree | 39462aa48bef10131eb36c22b38e9566336438f2 /chrome/browser/autofill/autofill_infobar_delegate.cc | |
parent | 8b160034c47761a7cefd93019d0c45b9f7911be7 (diff) | |
download | chromium_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.cc | 76 |
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; +} |