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

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: 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 #if defined(UNIT_TEST)
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, 35 return scoped_ptr<ConfirmInfoBarDelegate>(
37 const AutofillMetrics* metric_logger) { 36 new AutofillCCInfoBarDelegate(NULL, delegate.Pass()));
38 return scoped_ptr<ConfirmInfoBarDelegate>(new AutofillCCInfoBarDelegate(
39 NULL, credit_card, personal_data, metric_logger));
40 } 37 }
41 #endif 38 #endif
42 39
43 private: 40 private:
44 AutofillCCInfoBarDelegate(InfoBarService* infobar_service, 41 AutofillCCInfoBarDelegate(
45 const CreditCard* credit_card, 42 InfoBarService* infobar_service,
46 PersonalDataManager* personal_data, 43 scoped_ptr<autofill::AutofillCCImportConfirmationDelegate> delegate);
47 const AutofillMetrics* metric_logger);
48 virtual ~AutofillCCInfoBarDelegate(); 44 virtual ~AutofillCCInfoBarDelegate();
49 45
50 void LogUserAction(AutofillMetrics::InfoBarMetric user_action);
51
52 // ConfirmInfoBarDelegate: 46 // ConfirmInfoBarDelegate:
53 virtual void InfoBarDismissed() OVERRIDE; 47 virtual void InfoBarDismissed() OVERRIDE;
54 virtual gfx::Image* GetIcon() const OVERRIDE; 48 virtual gfx::Image* GetIcon() const OVERRIDE;
55 virtual Type GetInfoBarType() const OVERRIDE; 49 virtual Type GetInfoBarType() const OVERRIDE;
56 virtual bool ShouldExpireInternal( 50 virtual bool ShouldExpireInternal(
57 const content::LoadCommittedDetails& details) const OVERRIDE; 51 const content::LoadCommittedDetails& details) const OVERRIDE;
58 virtual string16 GetMessageText() const OVERRIDE; 52 virtual string16 GetMessageText() const OVERRIDE;
59 virtual string16 GetButtonLabel(InfoBarButton button) const OVERRIDE; 53 virtual string16 GetButtonLabel(InfoBarButton button) const OVERRIDE;
60 virtual bool Accept() OVERRIDE; 54 virtual bool Accept() OVERRIDE;
61 virtual bool Cancel() OVERRIDE; 55 virtual bool Cancel() OVERRIDE;
62 virtual string16 GetLinkText() const OVERRIDE; 56 virtual string16 GetLinkText() const OVERRIDE;
63 virtual bool LinkClicked(WindowOpenDisposition disposition) OVERRIDE; 57 virtual bool LinkClicked(WindowOpenDisposition disposition) OVERRIDE;
64 58
65 // The credit card that should be saved if the user accepts the infobar. 59 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 60
76 // Did the user ever explicitly accept or dismiss this infobar? 61 // Did the user ever explicitly accept or dismiss this infobar?
77 bool had_user_interaction_; 62 bool had_user_interaction_;
Ilya Sherman 2013/03/04 21:07:34 IMO you should move this into the delegate as well
kaiwang 2013/03/05 01:48:56 Done.
78 63
79 FRIEND_TEST_ALL_PREFIXES(AutofillMetricsTest, CreditCardInfoBar); 64 FRIEND_TEST_ALL_PREFIXES(AutofillMetricsTest, CreditCardInfoBar);
80 65
81 DISALLOW_COPY_AND_ASSIGN(AutofillCCInfoBarDelegate); 66 DISALLOW_COPY_AND_ASSIGN(AutofillCCInfoBarDelegate);
82 }; 67 };
83 68
84 #endif // CHROME_BROWSER_AUTOFILL_AUTOFILL_CC_INFOBAR_DELEGATE_H_ 69 #endif // CHROME_BROWSER_AUTOFILL_AUTOFILL_CC_INFOBAR_DELEGATE_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698