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

Side by Side Diff: chrome/browser/ui/views/payments/payment_request_sheet_controller.h

Issue 2668063003: [Web Payments] Add Cancel button to all sheets (Closed)
Patch Set: Address feedback about footer row creation. Created 3 years, 10 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
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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_UI_VIEWS_PAYMENTS_PAYMENT_REQUEST_SHEET_CONTROLLER_H_ 5 #ifndef CHROME_BROWSER_UI_VIEWS_PAYMENTS_PAYMENT_REQUEST_SHEET_CONTROLLER_H_
6 #define CHROME_BROWSER_UI_VIEWS_PAYMENTS_PAYMENT_REQUEST_SHEET_CONTROLLER_H_ 6 #define CHROME_BROWSER_UI_VIEWS_PAYMENTS_PAYMENT_REQUEST_SHEET_CONTROLLER_H_
7 7
8 #include <memory> 8 #include <memory>
9 9
10 #include "base/logging.h"
11 #include "base/macros.h" 10 #include "base/macros.h"
11 #include "ui/views/controls/button/vector_icon_button_delegate.h"
12 12
13 namespace views { 13 namespace views {
14 class Button;
14 class View; 15 class View;
15 } 16 }
16 17
17 namespace payments { 18 namespace payments {
18 19
19 class PaymentRequestDialogView; 20 class PaymentRequestDialogView;
20 class PaymentRequest; 21 class PaymentRequest;
21 22
22 // The base class for objects responsible for the creation and event handling in 23 // The base class for objects responsible for the creation and event handling in
23 // views shown in the PaymentRequestDialog. 24 // views shown in the PaymentRequestDialog.
24 class PaymentRequestSheetController { 25 class PaymentRequestSheetController : public views::VectorIconButtonDelegate {
25 public: 26 public:
26 // Objects of this class are owned by |dialog|, so it's a non-owned pointer 27 // Objects of this class are owned by |dialog|, so it's a non-owned pointer
27 // that should be valid throughout this object's lifetime. 28 // that should be valid throughout this object's lifetime.
28 // |request| is also not owned by this and is guaranteed to outlive dialog. 29 // |request| is also not owned by this and is guaranteed to outlive dialog.
29 // Neither |request| or |dialog| should be null. 30 // Neither |request| or |dialog| should be null.
30 PaymentRequestSheetController(PaymentRequest* request, 31 PaymentRequestSheetController(PaymentRequest* request,
31 PaymentRequestDialogView* dialog) 32 PaymentRequestDialogView* dialog);
32 : request_(request), dialog_(dialog) { 33 ~PaymentRequestSheetController() override {}
33 DCHECK(request_);
34 DCHECK(dialog_);
35 }
36 virtual ~PaymentRequestSheetController() {}
37 34
38 virtual std::unique_ptr<views::View> CreateView() = 0; 35 virtual std::unique_ptr<views::View> CreateView() = 0;
39 36
40 // The PaymentRequest object associated with this instance of the dialog. 37 // The PaymentRequest object associated with this instance of the dialog.
41 // Caller should not take ownership of the result. 38 // Caller should not take ownership of the result.
42 PaymentRequest* request() { return request_; } 39 PaymentRequest* request() { return request_; }
43 40
44 // The dialog that contains and owns this object. 41 // The dialog that contains and owns this object.
45 // Caller should not take ownership of the result. 42 // Caller should not take ownership of the result.
46 PaymentRequestDialogView* dialog() { return dialog_; } 43 PaymentRequestDialogView* dialog() { return dialog_; }
47 44
45 // Creates and returns the primary action button for this sheet. It's
46 // typically a blue button with the "Pay" or "Done" labels. Subclasses may
47 // return an empty std::unique_ptr to indicate that no primary button should
48 // be displayed. The caller takes ownership of the button but the view is
49 // guaranteed to be outlived by the controller so subclasses may retain a raw
50 // pointer to the returned button (for example to control its enabled state).
51 virtual std::unique_ptr<views::Button> CreatePrimaryButton();
52
53 protected:
54 // views::VectorIconButtonDelegate:
55 void ButtonPressed(views::Button* sender, const ui::Event& event) override;
56
57 std::unique_ptr<views::View> CreatePaymentView(
Mathieu 2017/02/02 21:04:58 Comment to say it will add the footer from below
anthonyvd 2017/02/02 21:33:24 Oops, it was still in the utils file. Good catch,
58 std::unique_ptr<views::View> header_view,
59 std::unique_ptr<views::View> content_view);
60
61 // Creates the row of button containing the Pay, cancel, and extra buttons.
62 // |controller| is installed as the listener for button events.
63 std::unique_ptr<views::View> CreateFooterView();
64
48 private: 65 private:
49 // Not owned. Will outlive this. 66 // Not owned. Will outlive this.
50 PaymentRequest* request_; 67 PaymentRequest* request_;
51 // Not owned. Will outlive this. 68 // Not owned. Will outlive this.
52 PaymentRequestDialogView* dialog_; 69 PaymentRequestDialogView* dialog_;
53 70
54 DISALLOW_COPY_AND_ASSIGN(PaymentRequestSheetController); 71 DISALLOW_COPY_AND_ASSIGN(PaymentRequestSheetController);
55 }; 72 };
56 73
57 } // namespace payments 74 } // namespace payments
58 75
59 #endif // CHROME_BROWSER_UI_VIEWS_PAYMENTS_PAYMENT_REQUEST_SHEET_CONTROLLER_H_ 76 #endif // CHROME_BROWSER_UI_VIEWS_PAYMENTS_PAYMENT_REQUEST_SHEET_CONTROLLER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698