| Index: components/autofill/content/browser/wallet/wallet_address.h
|
| diff --git a/components/autofill/content/browser/wallet/wallet_address.h b/components/autofill/content/browser/wallet/wallet_address.h
|
| deleted file mode 100644
|
| index e3e94bbc7e9e6eb5bc08a741e8542dbe808829fb..0000000000000000000000000000000000000000
|
| --- a/components/autofill/content/browser/wallet/wallet_address.h
|
| +++ /dev/null
|
| @@ -1,233 +0,0 @@
|
| -// Copyright 2013 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 COMPONENTS_AUTOFILL_CONTENT_BROWSER_WALLET_WALLET_ADDRESS_H_
|
| -#define COMPONENTS_AUTOFILL_CONTENT_BROWSER_WALLET_WALLET_ADDRESS_H_
|
| -
|
| -#include <stddef.h>
|
| -
|
| -#include <memory>
|
| -#include <string>
|
| -
|
| -#include "base/macros.h"
|
| -#include "base/strings/string16.h"
|
| -#include "components/autofill/core/browser/phone_number_i18n.h"
|
| -
|
| -namespace base {
|
| -class DictionaryValue;
|
| -}
|
| -
|
| -namespace autofill {
|
| -
|
| -class AutofillProfile;
|
| -class AutofillType;
|
| -
|
| -namespace wallet {
|
| -
|
| -// TODO(ahutter): This address is a lot like
|
| -// components/autofill/core/browser/address.h. There should be a super
|
| -// class that both extend from to clean up duplicated code. See
|
| -// http://crbug.com/164463.
|
| -
|
| -// Address contains various address fields that have been populated from the
|
| -// user's Online Wallet. It is loosely modeled as a subet of the OASIS
|
| -// "extensible Address Language" (xAL); see
|
| -// http://www.oasis-open.org/committees/ciq/download.shtml.
|
| -class Address {
|
| - public:
|
| - // TODO(ahutter): Use additional fields (descriptive_name, is_post_box,
|
| - // is_valid, is_default) when SaveToWallet is implemented.
|
| - // See http://crbug.com/164284.
|
| -
|
| - Address();
|
| -
|
| - // Using the raw info in |profile|, create a wallet::Address.
|
| - explicit Address(const AutofillProfile& profile);
|
| -
|
| - Address(const std::string& country_name_code,
|
| - const base::string16& recipient_name,
|
| - const std::vector<base::string16>& street_address,
|
| - const base::string16& locality_name,
|
| - const base::string16& dependent_locality_name,
|
| - const base::string16& administrative_area_name,
|
| - const base::string16& postal_code_number,
|
| - const base::string16& sorting_code,
|
| - const base::string16& phone_number,
|
| - const std::string& object_id,
|
| - const std::string& language_code);
|
| -
|
| - ~Address();
|
| -
|
| - // Returns an empty scoped_ptr if input is invalid or a valid address that is
|
| - // selectable for Google Wallet use. Does not require "id" in |dictionary|.
|
| - // IDs are not required for billing addresses.
|
| - static std::unique_ptr<Address> CreateAddress(
|
| - const base::DictionaryValue& dictionary);
|
| -
|
| - // TODO(ahutter): Make obvious in the function name that this public method
|
| - // only works for shipping address and assumes existance of "postal_address".
|
| - // Builds an Address from |dictionary|, which must have an "id" field. This
|
| - // function is designed for use with shipping addresses. The function may fail
|
| - // and return an empty pointer if its input is invalid.
|
| - static std::unique_ptr<Address> CreateAddressWithID(
|
| - const base::DictionaryValue& dictionary);
|
| -
|
| - // Returns an empty scoped_ptr if input in invalid or a valid address that
|
| - // can only be used for displaying to the user.
|
| - static std::unique_ptr<Address> CreateDisplayAddress(
|
| - const base::DictionaryValue& dictionary);
|
| -
|
| - // If an address is being upgraded, it will be sent to the server in a
|
| - // different format and with a few additional fields set, most importantly
|
| - // |object_id_|.
|
| - std::unique_ptr<base::DictionaryValue> ToDictionaryWithID() const;
|
| -
|
| - // Newly created addresses will not have an associated |object_id_| and are
|
| - // sent to the server in a slightly different format.
|
| - std::unique_ptr<base::DictionaryValue> ToDictionaryWithoutID() const;
|
| -
|
| - // Returns a string that summarizes this address, suitable for display to
|
| - // the user.
|
| - base::string16 DisplayName() const;
|
| -
|
| - // Returns a string that could be used as a sub-label, suitable for display
|
| - // to the user together with DisplayName().
|
| - base::string16 DisplayNameDetail() const;
|
| -
|
| - // Returns the phone number as a string that is suitable for display to the
|
| - // user.
|
| - base::string16 DisplayPhoneNumber() const;
|
| -
|
| - // Returns data appropriate for |type|.
|
| - base::string16 GetInfo(const AutofillType& type,
|
| - const std::string& app_locale) const;
|
| -
|
| - const std::string& country_name_code() const { return country_name_code_; }
|
| - const base::string16& recipient_name() const { return recipient_name_; }
|
| - const std::vector<base::string16>& street_address() const {
|
| - return street_address_;
|
| - }
|
| - const base::string16& locality_name() const { return locality_name_; }
|
| - const base::string16& administrative_area_name() const {
|
| - return administrative_area_name_;
|
| - }
|
| - const base::string16& postal_code_number() const {
|
| - return postal_code_number_;
|
| - }
|
| - const base::string16& phone_number() const { return phone_number_; }
|
| - const std::string& object_id() const { return object_id_; }
|
| - bool is_complete_address() const {
|
| - return is_complete_address_;
|
| - }
|
| - const std::string& language_code() const { return language_code_; }
|
| -
|
| - void set_country_name_code(const std::string& country_name_code) {
|
| - country_name_code_ = country_name_code;
|
| - }
|
| - void set_recipient_name(const base::string16& recipient_name) {
|
| - recipient_name_ = recipient_name;
|
| - }
|
| - void set_street_address(const std::vector<base::string16>& street_address) {
|
| - street_address_ = street_address;
|
| - }
|
| - void set_locality_name(const base::string16& locality_name) {
|
| - locality_name_ = locality_name;
|
| - }
|
| - void set_dependent_locality_name(
|
| - const base::string16& dependent_locality_name) {
|
| - dependent_locality_name_ = dependent_locality_name;
|
| - }
|
| - void set_administrative_area_name(
|
| - const base::string16& administrative_area_name) {
|
| - administrative_area_name_ = administrative_area_name;
|
| - }
|
| - void set_postal_code_number(const base::string16& postal_code_number) {
|
| - postal_code_number_ = postal_code_number;
|
| - }
|
| - void set_sorting_code(const base::string16& sorting_code) {
|
| - sorting_code_ = sorting_code;
|
| - }
|
| - void SetPhoneNumber(const base::string16& phone_number);
|
| - void set_object_id(const std::string& object_id) {
|
| - object_id_ = object_id;
|
| - }
|
| - void set_is_complete_address(bool is_complete_address) {
|
| - is_complete_address_ = is_complete_address;
|
| - }
|
| - void set_language_code(const std::string& language_code) {
|
| - language_code_ = language_code;
|
| - }
|
| -
|
| - // Tests if this address exact matches |other|. This method can be used to
|
| - // cull duplicates. It wouldn't make sense to have multiple identical street
|
| - // addresses with different identifiers or language codes (used for
|
| - // formatting). Therefore, |object_id| and |language_code| are ignored.
|
| - bool EqualsIgnoreID(const Address& other) const;
|
| -
|
| - // Tests if this address exact matches |other| including |object_id| and
|
| - // |language_code|.
|
| - bool operator==(const Address& other) const;
|
| - bool operator!=(const Address& other) const;
|
| -
|
| - private:
|
| - // Gets the street address on the given line (0-indexed).
|
| - base::string16 GetStreetAddressLine(size_t line) const;
|
| -
|
| - // |country_name_code_| should be an ISO 3166-1-alpha-2 (two letter codes, as
|
| - // used in DNS). For example, "GB".
|
| - std::string country_name_code_;
|
| -
|
| - // The recipient's name. For example "John Doe".
|
| - base::string16 recipient_name_;
|
| -
|
| - // Address lines (arbitrarily many).
|
| - std::vector<base::string16> street_address_;
|
| -
|
| - // Locality. This is something of a fuzzy term, but it generally refers to
|
| - // the city/town portion of an address.
|
| - // Examples: US city, IT comune, UK post town.
|
| - base::string16 locality_name_;
|
| -
|
| - // Dependent locality is used in Korea and China.
|
| - // Example: a Chinese county under the authority of a prefecture-level city.
|
| - base::string16 dependent_locality_name_;
|
| -
|
| - // Top-level administrative subdivision of this country.
|
| - // Examples: US state, IT region, UK constituent nation, JP prefecture.
|
| - // Note: this must be in short form, e.g. TX rather than Texas.
|
| - base::string16 administrative_area_name_;
|
| -
|
| - // Despite the name, |postal_code_number_| values are frequently alphanumeric.
|
| - // Examples: "94043", "SW1W", "SW1W 9TQ".
|
| - base::string16 postal_code_number_;
|
| -
|
| - // Sorting code, e.g. CEDEX in France.
|
| - base::string16 sorting_code_;
|
| -
|
| - // A valid international phone number. If |phone_number_| is a user provided
|
| - // value, it should have been validated using libphonenumber by clients of
|
| - // this class before being set; see http://code.google.com/p/libphonenumber/.
|
| - base::string16 phone_number_;
|
| -
|
| - // The parsed phone number.
|
| - i18n::PhoneObject phone_object_;
|
| -
|
| - // Externalized Online Wallet id for this address.
|
| - std::string object_id_;
|
| -
|
| - // Server's understanding of this address as complete address or not.
|
| - bool is_complete_address_;
|
| -
|
| - // The BCP 47 language code that can be used for formatting this address for
|
| - // display.
|
| - std::string language_code_;
|
| -
|
| - // This class is intentionally copyable.
|
| - DISALLOW_ASSIGN(Address);
|
| -};
|
| -
|
| -} // namespace wallet
|
| -} // namespace autofill
|
| -
|
| -#endif // COMPONENTS_AUTOFILL_CONTENT_BROWSER_WALLET_WALLET_ADDRESS_H_
|
|
|