Chromium Code Reviews| Index: ios/chrome/browser/ui/payments/credit_card_edit_mediator.mm |
| diff --git a/ios/chrome/browser/ui/payments/credit_card_edit_mediator.mm b/ios/chrome/browser/ui/payments/credit_card_edit_mediator.mm |
| index 13e75e4c2cf5de9f4e87af2cec07621836a17bb9..5a8dd0937bddf654cd80d3583f3f021d54489889 100644 |
| --- a/ios/chrome/browser/ui/payments/credit_card_edit_mediator.mm |
| +++ b/ios/chrome/browser/ui/payments/credit_card_edit_mediator.mm |
| @@ -15,7 +15,6 @@ |
| #include "ios/chrome/browser/payments/payment_request.h" |
| #import "ios/chrome/browser/payments/payment_request_util.h" |
| #import "ios/chrome/browser/ui/autofill/autofill_ui_type.h" |
| -#import "ios/chrome/browser/ui/autofill/autofill_ui_type_util.h" |
| #import "ios/chrome/browser/ui/payments/cells/accepted_payment_methods_item.h" |
| #import "ios/chrome/browser/ui/payments/cells/payment_method_item.h" |
| #import "ios/chrome/browser/ui/payments/payment_request_edit_consumer.h" |
| @@ -28,7 +27,6 @@ |
| #endif |
| namespace { |
| -using ::AutofillUITypeFromAutofillType; |
| using ::autofill::data_util::GetIssuerNetworkForBasicCardIssuerNetwork; |
| using ::autofill::data_util::GetPaymentRequestData; |
| using ::payment_request_util::GetBillingAddressLabelFromAutofillProfile; |
| @@ -73,7 +71,7 @@ using ::payment_request_util::GetBillingAddressLabelFromAutofillProfile; |
| [self.consumer setEditorFields:[self createEditorFields]]; |
| } |
| -#pragma mark - CreditCardEditViewControllerDataSource |
| +#pragma mark - PaymentRequestEditViewControllerDataSource |
| - (CollectionViewItem*)headerItem { |
| if (_creditCard && !autofill::IsCreditCardLocal(*_creditCard)) { |
| @@ -118,9 +116,13 @@ using ::payment_request_util::GetBillingAddressLabelFromAutofillProfile; |
| return !_creditCard || autofill::IsCreditCardLocal(*_creditCard); |
| } |
| -- (UIImage*)cardTypeIconFromCardNumber:(NSString*)cardNumber { |
| +- (UIImage*)iconIdentifyingEditorFied:(EditorField*)field { |
|
lpromero
2017/05/30 12:35:45
s/Fied/Field. The typo is also in the protocol dec
Moe
2017/05/31 03:21:11
Done.
|
| + // Early return if the field is not the credit card number field. |
| + if (field.autofillUIType != AutofillUITypeCreditCardNumber) |
| + return nil; |
| + |
| const char* issuerNetwork = autofill::CreditCard::GetCardNetwork( |
| - base::SysNSStringToUTF16(cardNumber)); |
| + base::SysNSStringToUTF16(field.value)); |
| // This should not happen in Payment Request. |
| if (issuerNetwork == autofill::kGenericCard) |
| return nil; |
| @@ -186,40 +188,40 @@ using ::payment_request_util::GetBillingAddressLabelFromAutofillProfile; |
| ? [NSString stringWithFormat:@"%04d", _creditCard->expiration_year()] |
| : nil; |
| - NSMutableArray* editorFields = [[NSMutableArray alloc] init]; |
| - [editorFields addObjectsFromArray:@[ |
| + return @[ |
| [[EditorField alloc] |
| - initWithAutofillUIType:AutofillUITypeFromAutofillType( |
| - autofill::CREDIT_CARD_NUMBER) |
| + initWithAutofillUIType:AutofillUITypeCreditCardNumber |
| fieldType:EditorFieldTypeTextField |
| label:l10n_util::GetNSString(IDS_PAYMENTS_CARD_NUMBER) |
| value:creditCardNumber |
| required:YES], |
| [[EditorField alloc] |
| - initWithAutofillUIType:AutofillUITypeFromAutofillType( |
| - autofill::CREDIT_CARD_NAME_FULL) |
| + initWithAutofillUIType:AutofillUITypeCreditCardHolderFullName |
| fieldType:EditorFieldTypeTextField |
| label:l10n_util::GetNSString(IDS_PAYMENTS_NAME_ON_CARD) |
| value:creditCardName |
| required:YES], |
| [[EditorField alloc] |
| - initWithAutofillUIType:AutofillUITypeFromAutofillType( |
| - autofill::CREDIT_CARD_EXP_MONTH) |
| + initWithAutofillUIType:AutofillUITypeCreditCardExpMonth |
| fieldType:EditorFieldTypeTextField |
| label:l10n_util::GetNSString(IDS_PAYMENTS_EXP_MONTH) |
| value:creditCardExpMonth |
| required:YES], |
| [[EditorField alloc] |
| - initWithAutofillUIType:AutofillUITypeFromAutofillType( |
| - autofill::CREDIT_CARD_EXP_4_DIGIT_YEAR) |
| + initWithAutofillUIType:AutofillUITypeCreditCardExpYear |
| fieldType:EditorFieldTypeTextField |
| label:l10n_util::GetNSString(IDS_PAYMENTS_EXP_YEAR) |
| value:creditCardExpYear |
| - required:YES] |
| - ]]; |
| - // The billing address field goes at the end. |
| - [editorFields addObject:billingAddressEditorField]; |
| - return editorFields; |
| + required:YES], |
| + billingAddressEditorField, |
| + [[EditorField alloc] |
| + initWithAutofillUIType:AutofillUITypeCreditCardSaveToChrome |
| + fieldType:EditorFieldTypeSwitch |
| + label:l10n_util::GetNSString( |
| + IDS_PAYMENTS_SAVE_CARD_TO_DEVICE_CHECKBOX) |
| + value:@"YES" |
| + required:YES], |
| + ]; |
| } |
| @end |