blob: c0922492d0f191156a653b69bc7bda8acbaf075b (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
// Copyright (c) 2010 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/browser.h"
#include "chrome/browser/pref_service.h"
#include "chrome/browser/profile.h"
#include "chrome/browser/tab_contents/tab_contents.h"
#include "chrome/browser/tab_contents/tab_contents_delegate.h"
#include "chrome/common/pref_names.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),
browser_(NULL),
host_(host) {
if (tab_contents) {
browser_ = tab_contents->delegate()->GetBrowser();
PrefService* prefs = tab_contents->profile()->GetPrefs();
prefs->SetBoolean(prefs::kAutoFillInfoBarShown, true);
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() {
if (host_) {
host_->OnInfoBarClosed();
host_ = NULL;
}
// 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);
else if (button == BUTTON_CANCEL)
return l10n_util::GetString(IDS_AUTOFILL_INFOBAR_DENY);
else
NOTREACHED();
return std::wstring();
}
bool AutoFillInfoBarDelegate::Accept() {
if (host_) {
host_->OnInfoBarAccepted();
host_ = NULL;
}
return true;
}
bool AutoFillInfoBarDelegate::Cancel() {
if (host_) {
host_->OnInfoBarCancelled();
host_ = NULL;
}
return true;
}
std::wstring AutoFillInfoBarDelegate::GetLinkText() {
return l10n_util::GetString(IDS_AUTOFILL_LEARN_MORE);
}
bool AutoFillInfoBarDelegate::LinkClicked(WindowOpenDisposition disposition) {
browser_->OpenURL(GURL(kAutoFillLearnMoreUrl), GURL(), NEW_FOREGROUND_TAB,
PageTransition::TYPED);
return true;
}
|