OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 #include "components/autofill/content/browser/autocheckout_manager.h" | 5 #include "components/autofill/content/browser/autocheckout_manager.h" |
6 | 6 |
7 #include "base/basictypes.h" | 7 #include "base/basictypes.h" |
8 #include "base/bind.h" | 8 #include "base/bind.h" |
9 #include "base/strings/utf_string_conversions.h" | 9 #include "base/strings/utf_string_conversions.h" |
10 #include "components/autofill/content/browser/autocheckout_request_manager.h" | 10 #include "components/autofill/content/browser/autocheckout_request_manager.h" |
(...skipping 333 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
344 metric_logger_->LogAutocheckoutBuyFlowMetric( | 344 metric_logger_->LogAutocheckoutBuyFlowMetric( |
345 AutofillMetrics::AUTOCHECKOUT_BUY_FLOW_STARTED); | 345 AutofillMetrics::AUTOCHECKOUT_BUY_FLOW_STARTED); |
346 | 346 |
347 profile_.reset(new AutofillProfile()); | 347 profile_.reset(new AutofillProfile()); |
348 credit_card_.reset(new CreditCard()); | 348 credit_card_.reset(new CreditCard()); |
349 billing_address_.reset(new AutofillProfile()); | 349 billing_address_.reset(new AutofillProfile()); |
350 | 350 |
351 for (size_t i = 0; i < result->field_count(); ++i) { | 351 for (size_t i = 0; i < result->field_count(); ++i) { |
352 const AutofillType& type = result->field(i)->Type(); | 352 const AutofillType& type = result->field(i)->Type(); |
353 const base::string16& value = result->field(i)->value; | 353 const base::string16& value = result->field(i)->value; |
354 if (type.native_type() == CREDIT_CARD_VERIFICATION_CODE) { | 354 NativeFieldType native_type = type.GetEquivalentNativeType(); |
| 355 if (native_type == CREDIT_CARD_VERIFICATION_CODE) { |
355 cvv_ = result->field(i)->value; | 356 cvv_ = result->field(i)->value; |
356 continue; | 357 continue; |
357 } | 358 } |
358 FieldTypeGroup group = type.group(); | 359 FieldTypeGroup group = type.group(); |
359 if (group == CREDIT_CARD) { | 360 if (group == CREDIT_CARD) { |
360 credit_card_->SetRawInfo(type.native_type(), value); | 361 credit_card_->SetRawInfo(native_type, value); |
361 // TODO(dgwallinga): Find a way of cleanly deprecating CREDIT_CARD_NAME. | 362 // TODO(dgwallinga): Find a way of cleanly deprecating CREDIT_CARD_NAME. |
362 // code.google.com/p/chromium/issues/detail?id=263498 | 363 // code.google.com/p/chromium/issues/detail?id=263498 |
363 if (type.native_type() == CREDIT_CARD_NAME) | 364 if (native_type == CREDIT_CARD_NAME) |
364 billing_address_->SetRawInfo(NAME_BILLING_FULL, value); | 365 billing_address_->SetRawInfo(NAME_BILLING_FULL, value); |
365 } else if (type.native_type() == ADDRESS_HOME_COUNTRY) { | 366 } else if (native_type == ADDRESS_HOME_COUNTRY) { |
366 profile_->SetInfo(type, value, autofill_manager_->app_locale()); | 367 if (IsBillingGroup(group)) |
367 } else if (type.native_type() == ADDRESS_BILLING_COUNTRY) { | 368 billing_address_->SetInfo(type, value, autofill_manager_->app_locale()); |
368 billing_address_->SetInfo(type, value, autofill_manager_->app_locale()); | 369 else |
| 370 profile_->SetInfo(type, value, autofill_manager_->app_locale()); |
369 } else if (IsBillingGroup(group)) { | 371 } else if (IsBillingGroup(group)) { |
370 billing_address_->SetRawInfo(type.native_type(), value); | 372 billing_address_->SetRawInfo(native_type, value); |
371 } else { | 373 } else { |
372 profile_->SetRawInfo(type.native_type(), value); | 374 profile_->SetRawInfo(native_type, value); |
373 } | 375 } |
374 } | 376 } |
375 | 377 |
376 // Page types only available in first-page meta data, so save | 378 // Page types only available in first-page meta data, so save |
377 // them for use later as we navigate. | 379 // them for use later as we navigate. |
378 page_types_ = page_meta_data_->page_types; | 380 page_types_ = page_meta_data_->page_types; |
379 SetStepProgressForPage(page_meta_data_->current_page_number, | 381 SetStepProgressForPage(page_meta_data_->current_page_number, |
380 AUTOCHECKOUT_STEP_STARTED); | 382 AUTOCHECKOUT_STEP_STARTED); |
381 | 383 |
382 FillForms(); | 384 FillForms(); |
(...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
442 } | 444 } |
443 | 445 |
444 void AutocheckoutManager::SetValue(const AutofillField& field, | 446 void AutocheckoutManager::SetValue(const AutofillField& field, |
445 FormFieldData* field_to_fill) { | 447 FormFieldData* field_to_fill) { |
446 // No-op if Autofill server doesn't know about the field. | 448 // No-op if Autofill server doesn't know about the field. |
447 if (field.server_type() == NO_SERVER_DATA) | 449 if (field.server_type() == NO_SERVER_DATA) |
448 return; | 450 return; |
449 | 451 |
450 const AutofillType& type = field.Type(); | 452 const AutofillType& type = field.Type(); |
451 | 453 |
452 if (type.native_type() == FIELD_WITH_DEFAULT_VALUE) { | 454 NativeFieldType native_type = type.GetEquivalentNativeType(); |
| 455 if (native_type == FIELD_WITH_DEFAULT_VALUE) { |
453 // For a form with radio buttons, like: | 456 // For a form with radio buttons, like: |
454 // <form> | 457 // <form> |
455 // <input type="radio" name="sex" value="male">Male<br> | 458 // <input type="radio" name="sex" value="male">Male<br> |
456 // <input type="radio" name="sex" value="female">Female | 459 // <input type="radio" name="sex" value="female">Female |
457 // </form> | 460 // </form> |
458 // If the default value specified at the server is "female", then | 461 // If the default value specified at the server is "female", then |
459 // Autofill server responds back with following field mappings | 462 // Autofill server responds back with following field mappings |
460 // (fieldtype: FIELD_WITH_DEFAULT_VALUE, value: "female") | 463 // (fieldtype: FIELD_WITH_DEFAULT_VALUE, value: "female") |
461 // (fieldtype: FIELD_WITH_DEFAULT_VALUE, value: "female") | 464 // (fieldtype: FIELD_WITH_DEFAULT_VALUE, value: "female") |
462 // Note that, the field mapping is repeated twice to respond to both the | 465 // Note that, the field mapping is repeated twice to respond to both the |
(...skipping 13 matching lines...) Expand all Loading... |
476 } else if (field.form_control_type == "select-one") { | 479 } else if (field.form_control_type == "select-one") { |
477 field_to_fill->value = default_value; | 480 field_to_fill->value = default_value; |
478 } else { | 481 } else { |
479 // FIELD_WITH_DEFAULT_VALUE should not be used for other type of fields. | 482 // FIELD_WITH_DEFAULT_VALUE should not be used for other type of fields. |
480 NOTREACHED(); | 483 NOTREACHED(); |
481 } | 484 } |
482 return; | 485 return; |
483 } | 486 } |
484 | 487 |
485 // Handle verification code directly. | 488 // Handle verification code directly. |
486 if (type.native_type() == CREDIT_CARD_VERIFICATION_CODE) { | 489 if (native_type == CREDIT_CARD_VERIFICATION_CODE) { |
487 field_to_fill->value = cvv_; | 490 field_to_fill->value = cvv_; |
488 return; | 491 return; |
489 } | 492 } |
490 | 493 |
491 if (type.group() == CREDIT_CARD) { | 494 if (type.group() == CREDIT_CARD) { |
492 credit_card_->FillFormField( | 495 credit_card_->FillFormField( |
493 field, 0, autofill_manager_->app_locale(), field_to_fill); | 496 field, 0, autofill_manager_->app_locale(), field_to_fill); |
494 } else if (IsBillingGroup(type.group())) { | 497 } else if (IsBillingGroup(type.group())) { |
495 billing_address_->FillFormField( | 498 billing_address_->FillFormField( |
496 field, 0, autofill_manager_->app_locale(), field_to_fill); | 499 field, 0, autofill_manager_->app_locale(), field_to_fill); |
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
546 | 549 |
547 SendAutocheckoutStatus(status); | 550 SendAutocheckoutStatus(status); |
548 if (status == SUCCESS) | 551 if (status == SUCCESS) |
549 autofill_manager_->delegate()->OnAutocheckoutSuccess(); | 552 autofill_manager_->delegate()->OnAutocheckoutSuccess(); |
550 else | 553 else |
551 autofill_manager_->delegate()->OnAutocheckoutError(); | 554 autofill_manager_->delegate()->OnAutocheckoutError(); |
552 in_autocheckout_flow_ = false; | 555 in_autocheckout_flow_ = false; |
553 } | 556 } |
554 | 557 |
555 } // namespace autofill | 558 } // namespace autofill |
OLD | NEW |