blob: f5037c69516f827f4bc4159a412b4670aa944fde [file] [log] [blame]
// Copyright 2015 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_DETAIL_INPUT_H_
#define COMPONENTS_AUTOFILL_CORE_BROWSER_DETAIL_INPUT_H_
#include <vector>
#include "base/strings/string16.h"
#include "components/autofill/core/browser/field_types.h"
namespace autofill {
// This struct describes a single input control for the imperative autocomplete
// dialog.
struct DetailInput {
enum Length {
SHORT, // Shares a line with other short inputs, like display: inline.
SHORT_EOL, // Like SHORT but starts a new line directly afterward. Used to
// separate groups of short inputs into different lines.
LONG, // Will be given its own full line, like display: block.
NONE, // Input will not be shown.
};
// Returns whether this input can spread across multiple lines.
bool IsMultiline() const;
// Used to determine which inputs share lines when laying out.
Length length;
ServerFieldType type;
// Text shown when the input is at its default state (e.g. empty).
base::string16 placeholder_text;
// A number between 0 and 1.0 that describes how much of the horizontal space
// in the row should be allotted to this input. 0 is equivalent to 1.
float expand_weight;
// When non-empty, indicates the starting value for this input. This will be
// used when the user is editing existing data.
base::string16 initial_value;
};
typedef std::vector<DetailInput> DetailInputs;
} // namespace autofill
#endif // COMPONENTS_AUTOFILL_CORE_BROWSER_DETAIL_INPUT_H_