// Copyright (c) 2011 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 CHROME_BROWSER_AUTOFILL_AUTOFILL_PROFILE_H_
#define CHROME_BROWSER_AUTOFILL_AUTOFILL_PROFILE_H_
#pragma once
#include <stddef.h>
#include <list>
#include <ostream>
#include <string>
#include <vector>
#ifdef ANDROID
#include "base/base_api.h"
#endif
#include "base/string16.h"
#include "chrome/browser/autofill/address.h"
#include "chrome/browser/autofill/autofill_type.h"
#include "chrome/browser/autofill/contact_info.h"
#include "chrome/browser/autofill/fax_number.h"
#include "chrome/browser/autofill/field_types.h"
#include "chrome/browser/autofill/form_group.h"
#include "chrome/browser/autofill/home_phone_number.h"
// A collection of FormGroups stored in a profile. AutofillProfile also
// implements the FormGroup interface so that owners of this object can request
// form information from the profile, and the profile will delegate the request
// to the requested form group type.
class
#ifdef ANDROID
BASE_API
#endif
AutofillProfile : public FormGroup {
public:
explicit AutofillProfile(const std::string& guid);
// For use in STL containers.
AutofillProfile();
AutofillProfile(const AutofillProfile& profile);
virtual ~AutofillProfile();
AutofillProfile& operator=(const AutofillProfile& profile);
// FormGroup:
virtual void GetPossibleFieldTypes(const string16& text,
FieldTypeSet* possible_types) const;
virtual void GetAvailableFieldTypes(FieldTypeSet* available_types) const;
virtual string16 GetInfo(AutofillFieldType type) const;
virtual void SetInfo(AutofillFieldType type, const string16& value);
// Multi-value equivalents to |GetInfo| and |SetInfo|.
void SetMultiInfo(AutofillFieldType type,
const std::vector<string16>& values);
void GetMultiInfo(AutofillFieldType type,
std::vector<string16>* values) const;
// Returns |true| if |type| accepts multi-values.
static bool SupportsMultiValue(AutofillFieldType type);
// The user-visible label of the profile, generated in relation to other
// profiles. Shows at least 2 fields that differentiate profile from other
// profiles. See AdjustInferredLabels() further down for more description.
virtual const string16 Label() const;
// This guid is the primary identifier for |AutofillProfile| objects.
const std::string guid() const { return guid_; }
void set_guid(const std::string& guid) { guid_ = guid; }
// Accessors for the stored address's country code.
const std::string CountryCode() const;
void SetCountryCode(const std::string& country_code);
// Adjusts the labels according to profile data.
// Labels contain minimal different combination of:
// 1. Full name.
// 2. Address.
// 3. E-mail.
// 4. Phone.
// 5. Fax.
// 6. Company name.
// Profile labels are changed accordingly to these rules.
// Returns true if any of the profiles were updated.
// This function is useful if you want to adjust unique labels for all
// profiles. For non permanent situations (selection of profile, when user
// started typing in the field, for example) use CreateInferredLabels().
static bool AdjustInferredLabels(std::vector<AutofillProfile*>* profiles);
// Creates inferred labels for |profiles|, according to the rules above and
// stores them in |created_labels|. If |suggested_fields| is not NULL, the
// resulting label fields are drawn from |suggested_fields|, except excluding
// |excluded_field|. Otherwise, the label fields are drawn from a default set,
// and |excluded_field| is ignored; by convention, it should be of
// |UNKNOWN_TYPE| when |suggested_fields| is NULL. Each label includes at
// least |minimal_fields_shown| fields, if possible.
static void CreateInferredLabels(
const std::vector<AutofillProfile*>* profiles,
const std::vector<AutofillFieldType>* suggested_fields,
AutofillFieldType excluded_field,
size_t minimal_fields_shown,
std::vector<string16>* created_labels);
// Returns true if there are no values (field types) set.
bool IsEmpty() const;
// Comparison for Sync. Returns 0 if the profile is the same as |this|,
// or < 0, or > 0 if it is different. The implied ordering can be used for
// culling duplicates. The ordering is based on collation order of the
// textual contents of the fields.
// GUIDs are not compared, only the values of the contents themselves.
// DEPRECATED: Use |CompareMulti| instead. |Compare| does not compare
// multi-valued items.
int Compare(const AutofillProfile& profile) const;
// Comparison for Sync. Same as |Compare| but includes multi-valued fields.
int CompareMulti(const AutofillProfile& profile) const;
// Equality operators compare GUIDs and the contents in the comparison.
// TODO(dhollowa): This needs to be made multi-profile once Sync updates.
bool operator==(const AutofillProfile& profile) const;
virtual bool operator!=(const AutofillProfile& profile) const;
// Returns concatenation of full name and address line 1. This acts as the
// basis of comparison for new values that are submitted through forms to
// aid with correct aggregation of new data.
const string16 PrimaryValue() const;
// Overwrites the single-valued field data in |profile| with this
// Profile. Or, for multi-valued fields append the new values.
void OverwriteWithOrAddTo(const AutofillProfile& profile);
private:
typedef std::vector<const FormGroup*> FormGroupList;
// Builds inferred label from the first |num_fields_to_include| non-empty
// fields in |label_fields|. Uses as many fields as possible if there are not
// enough non-empty fields.
string16 ConstructInferredLabel(
const std::vector<AutofillFieldType>& label_fields,
size_t num_fields_to_include) const;
// Creates inferred labels for |profiles| at indices corresponding to
// |indices|, and stores the results to the corresponding elements of
// |created_labels|. These labels include enough fields to differentiate among
// the profiles, if possible; and also at least |num_fields_to_include|
// fields, if possible. The label fields are drawn from |fields|.
static void CreateDifferentiatingLabels(
const std::vector<AutofillProfile*>& profiles,
const std::list<size_t>& indices,
const std::vector<AutofillFieldType>& fields,
size_t num_fields_to_include,
std::vector<string16>* created_labels);
// Utilities for listing and lookup of the data members that constitute
// user-visible profile information.
FormGroupList FormGroups() const;
const FormGroup* FormGroupForType(AutofillFieldType type) const;
FormGroup* MutableFormGroupForType(AutofillFieldType type);
// The label presented to the user when selecting a profile.
string16 label_;
// The guid of this profile.
std::string guid_;
// Personal information for this profile.
std::vector<NameInfo> name_;
std::vector<EmailInfo> email_;
CompanyInfo company_;
std::vector<HomePhoneNumber> home_number_;
std::vector<FaxNumber> fax_number_;
Address address_;
};
// So we can compare AutofillProfiles with EXPECT_EQ().
std::ostream& operator<<(std::ostream& os, const AutofillProfile& profile);
#endif // CHROME_BROWSER_AUTOFILL_AUTOFILL_PROFILE_H_