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

Unified Diff: chrome/browser/ui/views/payments/payment_request_sheet_controller.h

Issue 2579513002: [WebPayments] Factor out sheet-specific logic in Controllers. (Closed)
Patch Set: Address comments. Created 4 years 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/ui/views/payments/payment_request_sheet_controller.h
diff --git a/chrome/browser/ui/views/payments/payment_request_sheet_controller.h b/chrome/browser/ui/views/payments/payment_request_sheet_controller.h
new file mode 100644
index 0000000000000000000000000000000000000000..1a1bcd2575155b56b2f84ddec5dad193c2b093f7
--- /dev/null
+++ b/chrome/browser/ui/views/payments/payment_request_sheet_controller.h
@@ -0,0 +1,56 @@
+// Copyright 2016 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.
+
+#ifndef CHROME_BROWSER_UI_VIEWS_PAYMENTS_PAYMENT_REQUEST_SHEET_CONTROLLER_H_
+#define CHROME_BROWSER_UI_VIEWS_PAYMENTS_PAYMENT_REQUEST_SHEET_CONTROLLER_H_
+
+#include <memory>
+
+#include "base/macros.h"
+
+namespace views {
+class View;
+}
+
+namespace payments {
+
+class PaymentRequestDialog;
+class PaymentRequestImpl;
+
+// The base class for objects responsible for the creation and event handling in
+// views shown in the PaymentRequestDialog.
+class PaymentRequestSheetController {
+ public:
+ // Objects of this class are owned by |dialog|, so it's a weak pointer that
please use gerrit instead 2016/12/15 20:29:33 s/weak pointer/non-owned pointer/ This avoids con
anthonyvd 2016/12/15 20:58:08 Good point, done.
+ // should be valid throughout this object's lifetime.
+ // |impl| is also not owned by this and is guaranteed to outlive dialog.
+ PaymentRequestSheetController(PaymentRequestImpl* impl,
+ PaymentRequestDialog* dialog)
+ : impl_(impl),
+ dialog_(dialog) {}
+ virtual ~PaymentRequestSheetController() {}
+
+ virtual std::unique_ptr<views::View> CreateView() = 0;
+
+ // The PaymentRequestImpl object associated with this instance of the dialog.
+ // The pointer is owned by PaymentRequestFactory and will outlive this object.
please use gerrit instead 2016/12/15 20:29:33 All ownership comments should be from the point of
anthonyvd 2016/12/15 20:58:09 Done, see meta comment for some discussion.
+ PaymentRequestImpl* impl() { return impl_; }
+
+ // The dialog that contains and owns this object.
+ // The return value is owned by its parent view.
please use gerrit instead 2016/12/15 20:29:33 Ditto
anthonyvd 2016/12/15 20:58:08 Done.
+ PaymentRequestDialog* dialog() { return dialog_; }
+
+ private:
+ // Owned by PaymentRequestFactory and will outlive this object.
please use gerrit instead 2016/12/15 20:29:33 Let's restrict the private member variable comment
anthonyvd 2016/12/15 20:58:09 Done.
+ PaymentRequestImpl* impl_;
+
+ // Owned by its parent view.
please use gerrit instead 2016/12/15 20:29:33 // Not owned. Will outlive this. Is that correct
anthonyvd 2016/12/15 20:58:08 It is. Done.
+ PaymentRequestDialog* dialog_;
+
+ DISALLOW_COPY_AND_ASSIGN(PaymentRequestSheetController);
+};
+
+} // namespace payments
+
+#endif // CHROME_BROWSER_UI_VIEWS_PAYMENTS_PAYMENT_REQUEST_SHEET_CONTROLLER_H_

Powered by Google App Engine
This is Rietveld 408576698