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

Side by Side Diff: chrome/browser/autofill/autofill_cc_infobar_delegate.h

Issue 12378055: Make autofill stop depending on InfoBarService (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix tests Created 7 years, 9 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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 #ifndef CHROME_BROWSER_AUTOFILL_AUTOFILL_CC_INFOBAR_DELEGATE_H_ 5 #ifndef CHROME_BROWSER_AUTOFILL_AUTOFILL_CC_INFOBAR_DELEGATE_H_
6 #define CHROME_BROWSER_AUTOFILL_AUTOFILL_CC_INFOBAR_DELEGATE_H_ 6 #define CHROME_BROWSER_AUTOFILL_AUTOFILL_CC_INFOBAR_DELEGATE_H_
7 7
8 #include "base/basictypes.h" 8 #include "base/basictypes.h"
9 #include "base/gtest_prod_util.h" 9 #include "base/gtest_prod_util.h"
10 #include "base/memory/scoped_ptr.h" 10 #include "base/memory/scoped_ptr.h"
11 #include "base/string16.h" 11 #include "base/string16.h"
12 #include "chrome/browser/api/infobars/confirm_infobar_delegate.h" 12 #include "chrome/browser/api/infobars/confirm_infobar_delegate.h"
13 #include "chrome/browser/autofill/autofill_metrics.h"
14 #include "ui/base/window_open_disposition.h" 13 #include "ui/base/window_open_disposition.h"
15 14
16 class CreditCard; 15 namespace autofill {
17 class PersonalDataManager; 16 class AutofillCCImportConfirmationDelegate;
17 }
18 18
19 namespace content { 19 namespace content {
20 struct LoadCommittedDetails; 20 struct LoadCommittedDetails;
21 } 21 }
22 22
23 // An InfoBar delegate that enables the user to allow or deny storing credit 23 // An InfoBar delegate that enables the user to allow or deny storing credit
24 // card information gathered from a form submission. 24 // card information gathered from a form submission.
25 class AutofillCCInfoBarDelegate : public ConfirmInfoBarDelegate { 25 class AutofillCCInfoBarDelegate : public ConfirmInfoBarDelegate {
26 public: 26 public:
27 // Creates an autofill credit card delegate and adds it to |infobar_service|. 27 // Creates an autofill credit card delegate and adds it to |infobar_service|.
28 static void Create(InfoBarService* infobar_service, 28 static void Create(
29 const CreditCard* credit_card, 29 InfoBarService* infobar_service,
30 PersonalDataManager* personal_data, 30 scoped_ptr<autofill::AutofillCCImportConfirmationDelegate> delegate);
31 const AutofillMetrics* metric_logger);
32 31
33 #if defined(UNIT_TEST) 32 // Only for unit tests.
Ilya Sherman 2013/03/05 04:37:39 Why did you remove the #if defined(UNIT_TEST)? Pr
kaiwang 2013/03/05 18:38:16 Using the ifdef, the function implementation has t
34 static scoped_ptr<ConfirmInfoBarDelegate> Create( 33 static scoped_ptr<ConfirmInfoBarDelegate> Create(
35 const CreditCard* credit_card, 34 scoped_ptr<autofill::AutofillCCImportConfirmationDelegate> delegate);
36 PersonalDataManager* personal_data,
37 const AutofillMetrics* metric_logger) {
38 return scoped_ptr<ConfirmInfoBarDelegate>(new AutofillCCInfoBarDelegate(
39 NULL, credit_card, personal_data, metric_logger));
40 }
41 #endif
42 35
43 private: 36 private:
44 AutofillCCInfoBarDelegate(InfoBarService* infobar_service, 37 AutofillCCInfoBarDelegate(
45 const CreditCard* credit_card, 38 InfoBarService* infobar_service,
46 PersonalDataManager* personal_data, 39 scoped_ptr<autofill::AutofillCCImportConfirmationDelegate> delegate);
47 const AutofillMetrics* metric_logger);
48 virtual ~AutofillCCInfoBarDelegate(); 40 virtual ~AutofillCCInfoBarDelegate();
49 41
50 void LogUserAction(AutofillMetrics::InfoBarMetric user_action);
51
52 // ConfirmInfoBarDelegate: 42 // ConfirmInfoBarDelegate:
53 virtual void InfoBarDismissed() OVERRIDE; 43 virtual void InfoBarDismissed() OVERRIDE;
54 virtual gfx::Image* GetIcon() const OVERRIDE; 44 virtual gfx::Image* GetIcon() const OVERRIDE;
55 virtual Type GetInfoBarType() const OVERRIDE; 45 virtual Type GetInfoBarType() const OVERRIDE;
56 virtual bool ShouldExpireInternal( 46 virtual bool ShouldExpireInternal(
57 const content::LoadCommittedDetails& details) const OVERRIDE; 47 const content::LoadCommittedDetails& details) const OVERRIDE;
58 virtual string16 GetMessageText() const OVERRIDE; 48 virtual string16 GetMessageText() const OVERRIDE;
59 virtual string16 GetButtonLabel(InfoBarButton button) const OVERRIDE; 49 virtual string16 GetButtonLabel(InfoBarButton button) const OVERRIDE;
60 virtual bool Accept() OVERRIDE; 50 virtual bool Accept() OVERRIDE;
61 virtual bool Cancel() OVERRIDE; 51 virtual bool Cancel() OVERRIDE;
62 virtual string16 GetLinkText() const OVERRIDE; 52 virtual string16 GetLinkText() const OVERRIDE;
63 virtual bool LinkClicked(WindowOpenDisposition disposition) OVERRIDE; 53 virtual bool LinkClicked(WindowOpenDisposition disposition) OVERRIDE;
64 54
65 // The credit card that should be saved if the user accepts the infobar. 55 scoped_ptr<autofill::AutofillCCImportConfirmationDelegate> delegate_;
66 scoped_ptr<const CreditCard> credit_card_;
67
68 // The personal data manager to which the credit card should be saved.
69 // Weak reference.
70 PersonalDataManager* personal_data_;
71
72 // For logging UMA metrics.
73 // Weak reference. Owned by the AutofillManager that initiated this infobar.
74 const AutofillMetrics* metric_logger_;
75
76 // Did the user ever explicitly accept or dismiss this infobar?
77 bool had_user_interaction_;
78 56
79 FRIEND_TEST_ALL_PREFIXES(AutofillMetricsTest, CreditCardInfoBar); 57 FRIEND_TEST_ALL_PREFIXES(AutofillMetricsTest, CreditCardInfoBar);
80 58
81 DISALLOW_COPY_AND_ASSIGN(AutofillCCInfoBarDelegate); 59 DISALLOW_COPY_AND_ASSIGN(AutofillCCInfoBarDelegate);
82 }; 60 };
83 61
84 #endif // CHROME_BROWSER_AUTOFILL_AUTOFILL_CC_INFOBAR_DELEGATE_H_ 62 #endif // CHROME_BROWSER_AUTOFILL_AUTOFILL_CC_INFOBAR_DELEGATE_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698