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

Side by Side Diff: ios/chrome/browser/payments/payment_items_display_view_controller.mm

Issue 2590943002: Removes two unnecessary cells + adds missing unit test for an existing cell (Closed)
Patch Set: 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 unified diff | Download patch
« no previous file with comments | « ios/chrome/browser/payments/cells/shipping_address_item_unittest.mm ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 #import "ios/chrome/browser/payments/payment_items_display_view_controller.h" 5 #import "ios/chrome/browser/payments/payment_items_display_view_controller.h"
6 6
7 #import "base/ios/weak_nsobject.h" 7 #import "base/ios/weak_nsobject.h"
8 #include "base/mac/foundation_util.h"
8 #include "base/mac/scoped_nsobject.h" 9 #include "base/mac/scoped_nsobject.h"
9 #include "base/strings/sys_string_conversions.h" 10 #include "base/strings/sys_string_conversions.h"
10 #include "components/autofill/core/browser/credit_card.h" 11 #include "components/autofill/core/browser/credit_card.h"
11 #import "ios/chrome/browser/payments/cells/order_summary_line_item.h"
12 #import "ios/chrome/browser/payments/cells/order_summary_total_item.h"
13 #import "ios/chrome/browser/ui/collection_view/cells/collection_view_detail_item .h" 12 #import "ios/chrome/browser/ui/collection_view/cells/collection_view_detail_item .h"
14 #import "ios/chrome/browser/ui/collection_view/cells/collection_view_item.h" 13 #import "ios/chrome/browser/ui/collection_view/cells/collection_view_item.h"
15 #import "ios/chrome/browser/ui/collection_view/collection_view_model.h" 14 #import "ios/chrome/browser/ui/collection_view/collection_view_model.h"
16 #import "ios/chrome/browser/ui/colors/MDCPalette+CrAdditions.h" 15 #import "ios/chrome/browser/ui/colors/MDCPalette+CrAdditions.h"
17 #import "ios/chrome/browser/ui/icons/chrome_icon.h" 16 #import "ios/chrome/browser/ui/icons/chrome_icon.h"
18 #include "ios/chrome/browser/ui/rtl_geometry.h" 17 #include "ios/chrome/browser/ui/rtl_geometry.h"
19 #include "ios/chrome/grit/ios_strings.h" 18 #include "ios/chrome/grit/ios_strings.h"
20 #import "ios/third_party/material_components_ios/src/components/Buttons/src/Mate rialButtons.h" 19 #import "ios/third_party/material_components_ios/src/components/Buttons/src/Mate rialButtons.h"
20 #import "ios/third_party/material_components_ios/src/components/Palettes/src/Mat erialPalettes.h"
21 #import "ios/third_party/material_roboto_font_loader_ios/src/src/MaterialRobotoF ontLoader.h"
21 #include "ui/base/l10n/l10n_util.h" 22 #include "ui/base/l10n/l10n_util.h"
22 23
23 NSString* const kPaymentItemsDisplayCollectionViewId = 24 NSString* const kPaymentItemsDisplayCollectionViewId =
24 @"kPaymentItemsDisplayCollectionViewId"; 25 @"kPaymentItemsDisplayCollectionViewId";
25 26
26 namespace { 27 namespace {
27 28
28 const CGFloat kButtonEdgeInset = 9; 29 const CGFloat kButtonEdgeInset = 9;
29 const CGFloat kSeparatorEdgeInset = 14; 30 const CGFloat kSeparatorEdgeInset = 14;
30 31
31 typedef NS_ENUM(NSInteger, SectionIdentifier) { 32 typedef NS_ENUM(NSInteger, SectionIdentifier) {
32 SectionIdentifierPayment = kSectionIdentifierEnumZero, 33 SectionIdentifierPayment = kSectionIdentifierEnumZero,
33 }; 34 };
34 35
35 typedef NS_ENUM(NSInteger, ItemType) { 36 typedef NS_ENUM(NSInteger, ItemType) {
36 ItemTypePaymentItem = kItemTypeEnumZero, // This is a repeated item type. 37 ItemTypePaymentItemTotal = kItemTypeEnumZero,
38 ItemTypePaymentItem, // This is a repeated item type.
37 }; 39 };
38 40
39 } // namespace 41 } // namespace
40 42
41 @interface PaymentItemsDisplayViewController () { 43 @interface PaymentItemsDisplayViewController () {
42 base::WeakNSProtocol<id<PaymentItemsDisplayViewControllerDelegate>> _delegate; 44 base::WeakNSProtocol<id<PaymentItemsDisplayViewControllerDelegate>> _delegate;
43 base::scoped_nsobject<MDCFlatButton> _payButton; 45 base::scoped_nsobject<MDCFlatButton> _payButton;
44 } 46 }
45 47
46 // Called when the user presses the return button. 48 // Called when the user presses the return button.
(...skipping 86 matching lines...) Expand 10 before | Expand all | Expand 10 after
133 - (void)loadModel { 135 - (void)loadModel {
134 [super loadModel]; 136 [super loadModel];
135 CollectionViewModel* model = self.collectionViewModel; 137 CollectionViewModel* model = self.collectionViewModel;
136 [model addSectionWithIdentifier:SectionIdentifierPayment]; 138 [model addSectionWithIdentifier:SectionIdentifierPayment];
137 139
138 NSNumberFormatter* currencyFormatter = 140 NSNumberFormatter* currencyFormatter =
139 [[[NSNumberFormatter alloc] init] autorelease]; 141 [[[NSNumberFormatter alloc] init] autorelease];
140 [currencyFormatter setNumberStyle:NSNumberFormatterCurrencyStyle]; 142 [currencyFormatter setNumberStyle:NSNumberFormatterCurrencyStyle];
141 143
142 // Add the total entry. 144 // Add the total entry.
143 OrderSummaryTotalItem* totalItem = [[[OrderSummaryTotalItem alloc] 145 CollectionViewDetailItem* totalItem = [[[CollectionViewDetailItem alloc]
144 initWithType:ItemTypePaymentItem] autorelease]; 146 initWithType:ItemTypePaymentItemTotal] autorelease];
145 totalItem.text = base::SysUTF16ToNSString(_total.label); 147 totalItem.text = base::SysUTF16ToNSString(_total.label);
146 148
147 NSString* currencyCode = base::SysUTF16ToNSString(_total.amount.currency); 149 NSString* currencyCode = base::SysUTF16ToNSString(_total.amount.currency);
148 NSDecimalNumber* value = [NSDecimalNumber 150 NSDecimalNumber* value = [NSDecimalNumber
149 decimalNumberWithString:SysUTF16ToNSString(_total.amount.value)]; 151 decimalNumberWithString:SysUTF16ToNSString(_total.amount.value)];
150 [currencyFormatter setCurrencyCode:currencyCode]; 152 [currencyFormatter setCurrencyCode:currencyCode];
151 totalItem.detailText = [currencyFormatter stringFromNumber:value]; 153 totalItem.detailText = [currencyFormatter stringFromNumber:value];
152 154
153 [model addItem:totalItem toSectionWithIdentifier:SectionIdentifierPayment]; 155 [model addItem:totalItem toSectionWithIdentifier:SectionIdentifierPayment];
154 156
155 // Add the line item entries. 157 // Add the line item entries.
156 for (size_t i = 0; i < _paymentItems.size(); ++i) { 158 for (size_t i = 0; i < _paymentItems.size(); ++i) {
157 web::PaymentItem paymentItem = _paymentItems[i]; 159 web::PaymentItem paymentItem = _paymentItems[i];
158 OrderSummaryLineItem* paymentItemItem = [[[OrderSummaryLineItem alloc] 160 CollectionViewDetailItem* paymentItemItem =
159 initWithType:ItemTypePaymentItem] autorelease]; 161 [[[CollectionViewDetailItem alloc] initWithType:ItemTypePaymentItem]
162 autorelease];
160 paymentItemItem.text = base::SysUTF16ToNSString(paymentItem.label); 163 paymentItemItem.text = base::SysUTF16ToNSString(paymentItem.label);
161 164
162 NSString* currencyCode = 165 NSString* currencyCode =
163 base::SysUTF16ToNSString(paymentItem.amount.currency); 166 base::SysUTF16ToNSString(paymentItem.amount.currency);
164 NSDecimalNumber* value = [NSDecimalNumber 167 NSDecimalNumber* value = [NSDecimalNumber
165 decimalNumberWithString:SysUTF16ToNSString(paymentItem.amount.value)]; 168 decimalNumberWithString:SysUTF16ToNSString(paymentItem.amount.value)];
166 [currencyFormatter setCurrencyCode:currencyCode]; 169 [currencyFormatter setCurrencyCode:currencyCode];
167 paymentItemItem.detailText = [currencyFormatter stringFromNumber:value]; 170 paymentItemItem.detailText = [currencyFormatter stringFromNumber:value];
168 171
169 [model addItem:paymentItemItem 172 [model addItem:paymentItemItem
170 toSectionWithIdentifier:SectionIdentifierPayment]; 173 toSectionWithIdentifier:SectionIdentifierPayment];
171 } 174 }
172 } 175 }
173 176
174 - (void)viewDidLoad { 177 - (void)viewDidLoad {
175 [super viewDidLoad]; 178 [super viewDidLoad];
176 self.collectionView.accessibilityIdentifier = 179 self.collectionView.accessibilityIdentifier =
177 kPaymentItemsDisplayCollectionViewId; 180 kPaymentItemsDisplayCollectionViewId;
178 181
179 // Customize collection view settings. 182 // Customize collection view settings.
180 self.styler.cellStyle = MDCCollectionViewCellStyleCard; 183 self.styler.cellStyle = MDCCollectionViewCellStyleCard;
181 self.styler.separatorInset = 184 self.styler.separatorInset =
182 UIEdgeInsetsMake(0, kSeparatorEdgeInset, 0, kSeparatorEdgeInset); 185 UIEdgeInsetsMake(0, kSeparatorEdgeInset, 0, kSeparatorEdgeInset);
183 } 186 }
184 187
188 #pragma mark UICollectionViewDataSource
189 - (UICollectionViewCell*)collectionView:(UICollectionView*)collectionView
190 cellForItemAtIndexPath:(nonnull NSIndexPath*)indexPath {
191 UICollectionViewCell* cell =
192 [super collectionView:collectionView cellForItemAtIndexPath:indexPath];
193
194 NSInteger itemType =
195 [self.collectionViewModel itemTypeForIndexPath:indexPath];
196 switch (itemType) {
197 case ItemTypePaymentItemTotal: {
Justin Donnelly 2016/12/20 15:44:23 I see that this is being done elsewhere in the cod
Justin Donnelly 2016/12/20 16:46:38 Ah, I see. Thanks for the explanation.
198 CollectionViewDetailCell* detailCell =
199 base::mac::ObjCCastStrict<CollectionViewDetailCell>(cell);
200 detailCell.textLabel.font =
201 [[MDFRobotoFontLoader sharedInstance] boldFontOfSize:14];
202 detailCell.textLabel.textColor = [[MDCPalette greyPalette] tint600];
203 detailCell.detailTextLabel.font =
204 [[MDFRobotoFontLoader sharedInstance] boldFontOfSize:14];
205 detailCell.detailTextLabel.textColor = [[MDCPalette greyPalette] tint900];
206 break;
207 }
208 case ItemTypePaymentItem: {
209 CollectionViewDetailCell* detailCell =
210 base::mac::ObjCCastStrict<CollectionViewDetailCell>(cell);
211 detailCell.textLabel.font =
212 [[MDFRobotoFontLoader sharedInstance] regularFontOfSize:14];
213 detailCell.textLabel.textColor = [[MDCPalette greyPalette] tint900];
214
215 detailCell.detailTextLabel.font =
216 [[MDFRobotoFontLoader sharedInstance] regularFontOfSize:14];
217 detailCell.detailTextLabel.textColor = [[MDCPalette greyPalette] tint900];
218 break;
219 }
220 default:
221 break;
222 }
223 return cell;
224 }
225
185 #pragma mark MDCCollectionViewStylingDelegate 226 #pragma mark MDCCollectionViewStylingDelegate
186 227
187 // There are no effects from touching the payment items so there should not be 228 // There are no effects from touching the payment items so there should not be
188 // an ink ripple. 229 // an ink ripple.
189 - (BOOL)collectionView:(UICollectionView*)collectionView 230 - (BOOL)collectionView:(UICollectionView*)collectionView
190 hidesInkViewAtIndexPath:(NSIndexPath*)indexPath { 231 hidesInkViewAtIndexPath:(NSIndexPath*)indexPath {
191 return YES; 232 return YES;
192 } 233 }
193 234
194 @end 235 @end
OLDNEW
« no previous file with comments | « ios/chrome/browser/payments/cells/shipping_address_item_unittest.mm ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698