// 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_CORE_BROWSER_AUTOFILL_COUNTRY_H_ #define COMPONENTS_AUTOFILL_CORE_BROWSER_AUTOFILL_COUNTRY_H_ #include #include #include "base/macros.h" #include "base/strings/string16.h" #include "components/autofill/core/browser/country_data.h" namespace autofill { // Stores data associated with a country. Strings are localized to the app // locale. class AutofillCountry { public: // Returns country data corresponding to the two-letter ISO code // |country_code|. AutofillCountry(const std::string& country_code, const std::string& locale); ~AutofillCountry(); // Returns the likely country code for |locale|, or "US" as a fallback if no // mapping from the locale is available. static const std::string CountryCodeForLocale(const std::string& locale); const std::string& country_code() const { return country_code_; } const base::string16& name() const { return name_; } const base::string16& postal_code_label() const { return postal_code_label_; } const base::string16& state_label() const { return state_label_; } // City is expected in a complete address for this country. bool requires_city() const { return (address_required_fields_ & ADDRESS_REQUIRES_CITY) != 0; } // State is expected in a complete address for this country. bool requires_state() const { return (address_required_fields_ & ADDRESS_REQUIRES_STATE) != 0; } // Zip is expected in a complete address for this country. bool requires_zip() const { return (address_required_fields_ & ADDRESS_REQUIRES_ZIP) != 0; } private: AutofillCountry(const std::string& country_code, const base::string16& name, const base::string16& postal_code_label, const base::string16& state_label); // The two-letter ISO-3166 country code. std::string country_code_; // The country's name, localized to the app locale. base::string16 name_; // The localized label for the postal code (or zip code) field. base::string16 postal_code_label_; // The localized label for the state (or province, district, etc.) field. base::string16 state_label_; // Address requirement field codes for the country. AddressRequiredFields address_required_fields_; DISALLOW_COPY_AND_ASSIGN(AutofillCountry); }; } // namespace autofill #endif // COMPONENTS_AUTOFILL_CORE_BROWSER_AUTOFILL_COUNTRY_H_