Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
F
Front-End
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abdullh.alsoleman
Front-End
Commits
c0b20a76
Unverified
Commit
c0b20a76
authored
Dec 23, 2018
by
Ian Hickson
Committed by
GitHub
Dec 23, 2018
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Some minor tweaks to InputDecoration (mainly docs). (#24643)
parent
2e2f19d3
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
106 additions
and
54 deletions
+106
-54
input_decorator.dart
packages/flutter/lib/src/material/input_decorator.dart
+106
-54
No files found.
packages/flutter/lib/src/material/input_decorator.dart
View file @
c0b20a76
...
@@ -1516,7 +1516,7 @@ class InputDecorator extends StatefulWidget {
...
@@ -1516,7 +1516,7 @@ class InputDecorator extends StatefulWidget {
_InputDecoratorState
createState
()
=>
_InputDecoratorState
();
_InputDecoratorState
createState
()
=>
_InputDecoratorState
();
/// The RenderBox that defines this decorator's "container". That's the
/// The RenderBox that defines this decorator's "container". That's the
/// area which is filled if [InputDecoration.
isF
illed] is true. It's the area
/// area which is filled if [InputDecoration.
f
illed] is true. It's the area
/// adjacent to [InputDecoration.icon] and above the widgets that contain
/// adjacent to [InputDecoration.icon] and above the widgets that contain
/// [InputDecoration.helperText], [InputDecoration.errorText], and
/// [InputDecoration.helperText], [InputDecoration.errorText], and
/// [InputDecoration.counterText].
/// [InputDecoration.counterText].
...
@@ -1956,8 +1956,9 @@ class InputDecoration {
...
@@ -1956,8 +1956,9 @@ class InputDecoration {
///
///
/// The [enabled] argument must not be null.
/// The [enabled] argument must not be null.
///
///
/// Only [prefix] or [prefixText] can be specified.
/// Only one of [prefix] and [prefixText] can be specified.
/// The same applies for [suffix] and [suffixText].
///
/// Similarly, only one of [suffix] and [suffixText] can be specified.
const
InputDecoration
({
const
InputDecoration
({
this
.
icon
,
this
.
icon
,
this
.
labelText
,
this
.
labelText
,
...
@@ -1995,8 +1996,8 @@ class InputDecoration {
...
@@ -1995,8 +1996,8 @@ class InputDecoration {
this
.
semanticCounterText
,
this
.
semanticCounterText
,
this
.
alignLabelWithHint
,
this
.
alignLabelWithHint
,
})
:
assert
(
enabled
!=
null
),
})
:
assert
(
enabled
!=
null
),
assert
(!(
prefix
!=
null
&&
prefixText
!=
null
),
'Declaring both prefix and prefixText is not
allowed
'
),
assert
(!(
prefix
!=
null
&&
prefixText
!=
null
),
'Declaring both prefix and prefixText is not
supported.
'
),
assert
(!(
suffix
!=
null
&&
suffixText
!=
null
),
'Declaring both suffix and suffixText is not
allowed
'
),
assert
(!(
suffix
!=
null
&&
suffixText
!=
null
),
'Declaring both suffix and suffixText is not
supported.
'
),
isCollapsed
=
false
;
isCollapsed
=
false
;
/// Defines an [InputDecorator] that is the same size as the input field.
/// Defines an [InputDecorator] that is the same size as the input field.
...
@@ -2052,7 +2053,7 @@ class InputDecoration {
...
@@ -2052,7 +2053,7 @@ class InputDecoration {
///
///
/// The trailing edge of the icon is padded by 16dps.
/// The trailing edge of the icon is padded by 16dps.
///
///
/// The decoration's container is the area which is filled if [
isF
illed] is
/// The decoration's container is the area which is filled if [
f
illed] is
/// true and bordered per the [border]. It's the area adjacent to
/// true and bordered per the [border]. It's the area adjacent to
/// [decoration.icon] and above the widgets that contain [helperText],
/// [decoration.icon] and above the widgets that contain [helperText],
/// [errorText], and [counterText].
/// [errorText], and [counterText].
...
@@ -2159,7 +2160,7 @@ class InputDecoration {
...
@@ -2159,7 +2160,7 @@ class InputDecoration {
/// The padding for the input decoration's container.
/// The padding for the input decoration's container.
///
///
/// The decoration's container is the area which is filled if [
isF
illed] is
/// The decoration's container is the area which is filled if [
f
illed] is
/// true and bordered per the [border]. It's the area adjacent to
/// true and bordered per the [border]. It's the area adjacent to
/// [decoration.icon] and above the widgets that contain [helperText],
/// [decoration.icon] and above the widgets that contain [helperText],
/// [errorText], and [counterText].
/// [errorText], and [counterText].
...
@@ -2176,8 +2177,8 @@ class InputDecoration {
...
@@ -2176,8 +2177,8 @@ class InputDecoration {
/// To create a collapsed input decoration, use [InputDecoration..collapsed].
/// To create a collapsed input decoration, use [InputDecoration..collapsed].
final
bool
isCollapsed
;
final
bool
isCollapsed
;
/// An icon that that appears before the [prefix
Text] and the input and within
/// An icon that that appears before the [prefix
] or [prefixText] and before
/// the decoration's container.
/// the
editable part of the text field, within the
decoration's container.
///
///
/// The size and color of the prefix icon is configured automatically using an
/// The size and color of the prefix icon is configured automatically using an
/// [IconTheme] and therefore does not need to be explicitly given in the
/// [IconTheme] and therefore does not need to be explicitly given in the
...
@@ -2187,44 +2188,71 @@ class InputDecoration {
...
@@ -2187,44 +2188,71 @@ class InputDecoration {
/// can be expanded beyond that. Anything larger than 24px will require
/// can be expanded beyond that. Anything larger than 24px will require
/// additional padding to ensure it matches the material spec of 12px padding
/// additional padding to ensure it matches the material spec of 12px padding
/// between the left edge of the input and leading edge of the prefix icon.
/// between the left edge of the input and leading edge of the prefix icon.
/// To pad the leading edge of the prefix icon:
/// The following snippet shows how to pad the leading edge of the prefix
/// icon:
///
///
/// ```dart
/// ```dart
/// prefixIcon: Padding(
/// prefixIcon: Padding(
/// padding: const EdgeInsetsDirectional.only(start: 12.0),
/// padding: const EdgeInsetsDirectional.only(start: 12.0),
/// child: myIcon, //
icon is 48px
widget.
/// child: myIcon, //
myIcon is a 48px-wide
widget.
/// )
/// )
/// ```
/// ```
///
///
/// The decoration's container is the area which is filled if [
isF
illed] is
/// The decoration's container is the area which is filled if [
f
illed] is
/// true and bordered per the [border]. It's the area adjacent to
/// true and bordered per the [border]. It's the area adjacent to
/// [decoration.icon] and above the widgets that contain [helperText],
/// [decoration.icon] and above the widgets that contain [helperText],
/// [errorText], and [counterText].
/// [errorText], and [counterText].
///
///
/// See [Icon], [ImageIcon].
/// See also:
///
/// * [Icon] and [ImageIcon], which are typically used to show icons.
/// * [prefix] and [prefixText], which are other ways to show content
/// before the text field (but after the icon).
/// * [suffixIcon], which is the same but on the trailing edge.
final
Widget
prefixIcon
;
final
Widget
prefixIcon
;
/// Optional widget to place on the line before the input.
/// Optional widget to place on the line before the input.
/// Can be used to add some padding to the [prefixText] or to
///
/// add a custom widget in front of the input. The widget's baseline
/// This can be used, for example, to add some padding to text that would
/// is lined up with the input baseline.
/// otherwise be specified using [prefixText], or to add a custom widget in
/// front of the input. The widget's baseline is lined up with the input
/// baseline.
///
///
/// Only one of [prefix] and [prefixText] can be specified.
/// Only one of [prefix] and [prefixText] can be specified.
///
/// The [prefix] appears after the [prefixIcon], if both are specified.
///
/// See also:
///
/// * [suffix], the equivalent but on the trailing edge.
final
Widget
prefix
;
final
Widget
prefix
;
/// Optional text prefix to place on the line before the input.
/// Optional text prefix to place on the line before the input.
///
///
/// Uses the [prefixStyle]. Uses [hintStyle] if [prefixStyle] isn't
/// Uses the [prefixStyle]. Uses [hintStyle] if [prefixStyle] isn't specified.
/// specified. Prefix is not returned as part of the input.
/// The prefix text is not returned as part of the user's input.
///
/// If a more elaborate prefix is required, consider using [prefix] instead.
/// Only one of [prefix] and [prefixText] can be specified.
///
/// The [prefixText] appears after the [prefixIcon], if both are specified.
///
/// See also:
///
/// * [suffixText], the equivalent but on the trailing edge.
final
String
prefixText
;
final
String
prefixText
;
/// The style to use for the [prefixText].
/// The style to use for the [prefixText].
///
///
/// If null, defaults to the [hintStyle].
/// If null, defaults to the [hintStyle].
///
/// See also:
///
/// * [suffixStyle], the equivalent but on the trailing edge.
final
TextStyle
prefixStyle
;
final
TextStyle
prefixStyle
;
/// An icon that that appears after the
input and [suffixText] and within
/// An icon that that appears after the
editable part of the text field and
/// the decoration's container.
///
after the [suffix] or [suffixText], within
the decoration's container.
///
///
/// The size and color of the suffix icon is configured automatically using an
/// The size and color of the suffix icon is configured automatically using an
/// [IconTheme] and therefore does not need to be explicitly given in the
/// [IconTheme] and therefore does not need to be explicitly given in the
...
@@ -2234,40 +2262,66 @@ class InputDecoration {
...
@@ -2234,40 +2262,66 @@ class InputDecoration {
/// can be expanded beyond that. Anything larger than 24px will require
/// can be expanded beyond that. Anything larger than 24px will require
/// additional padding to ensure it matches the material spec of 12px padding
/// additional padding to ensure it matches the material spec of 12px padding
/// between the right edge of the input and trailing edge of the prefix icon.
/// between the right edge of the input and trailing edge of the prefix icon.
/// To pad the trailing edge of the suffix icon:
/// The following snipped shows how to pad the trailing edge of the suffix
/// icon:
///
///
/// ```dart
/// ```dart
/// suffixIcon: Padding(
/// suffixIcon: Padding(
/// padding: const EdgeInsetsDirectional.only(end: 12.0),
/// padding: const EdgeInsetsDirectional.only(end: 12.0),
/// child: myIcon, //
icon is 48px
widget.
/// child: myIcon, //
myIcon is a 48px-wide
widget.
/// )
/// )
/// ```
/// ```
///
///
/// The decoration's container is the area which is filled if [
isF
illed] is
/// The decoration's container is the area which is filled if [
f
illed] is
/// true and bordered per the [border]. It's the area adjacent to
/// true and bordered per the [border]. It's the area adjacent to
/// [decoration.icon] and above the widgets that contain [helperText],
/// [decoration.icon] and above the widgets that contain [helperText],
/// [errorText], and [counterText].
/// [errorText], and [counterText].
///
///
/// See [Icon], [ImageIcon].
/// See also:
///
/// * [Icon] and [ImageIcon], which are typically used to show icons.
/// * [suffix] and [suffixText], which are other ways to show content
/// after the text field (but before the icon).
/// * [prefixIcon], which is the same but on the leading edge.
final
Widget
suffixIcon
;
final
Widget
suffixIcon
;
/// Optional widget to place on the line after the input.
/// Optional widget to place on the line after the input.
/// Can be used to add some padding to the [suffixText] or to
///
/// add a custom widget after the input. The widget's baseline
/// This can be used, for example, to add some padding to the text that would
/// is lined up with the input baseline.
/// otherwise be specified using [suffixText], or to add a custom widget after
/// the input. The widget's baseline is lined up with the input baseline.
///
///
/// Only one of [suffix] and [suffixText] can be specified.
/// Only one of [suffix] and [suffixText] can be specified.
///
/// The [suffix] appears before the [suffixIcon], if both are specified.
///
/// See also:
///
/// * [prefix], the equivalent but on the leading edge.
final
Widget
suffix
;
final
Widget
suffix
;
/// Optional text suffix to place on the line after the input.
/// Optional text suffix to place on the line after the input.
///
///
/// Uses the [suffixStyle]. Uses [hintStyle] if [suffixStyle] isn't
/// Uses the [suffixStyle]. Uses [hintStyle] if [suffixStyle] isn't specified.
/// specified. Suffix is not returned as part of the input.
/// The suffix text is not returned as part of the user's input.
///
/// If a more elaborate suffix is required, consider using [suffix] instead.
/// Only one of [suffix] and [suffixText] can be specified.
///
/// The [suffixText] appears before the [suffixIcon], if both are specified.
///
/// See also:
///
/// * [prefixText], the equivalent but on the leading edge.
final
String
suffixText
;
final
String
suffixText
;
/// The style to use for the [suffixText].
/// The style to use for the [suffixText].
///
///
/// If null, defaults to the [hintStyle].
/// If null, defaults to the [hintStyle].
///
/// See also:
///
/// * [prefixStyle], the equivalent but on the leading edge.
final
TextStyle
suffixStyle
;
final
TextStyle
suffixStyle
;
/// Optional text to place below the line as a character count.
/// Optional text to place below the line as a character count.
...
@@ -2285,10 +2339,10 @@ class InputDecoration {
...
@@ -2285,10 +2339,10 @@ class InputDecoration {
/// If true the decoration's container is filled with [fillColor].
/// If true the decoration's container is filled with [fillColor].
///
///
/// Typically this field set to true if [border] is
/// Typically this field set to true if [border] is
an
/// [
const UnderlineInputBorder()
].
/// [
UnderlineInputBorder
].
///
///
/// The decoration's container is the area which is filled if [
isF
illed] is
/// The decoration's container is the area which is filled if [
f
illed] is
/// true and bordered per the [border]. It's the area adjacent to
/// true and bordered per the [border]. It's the area adjacent to
/// [decoration.icon] and above the widgets that contain [helperText],
/// [decoration.icon] and above the widgets that contain [helperText],
/// [errorText], and [counterText].
/// [errorText], and [counterText].
...
@@ -2300,7 +2354,7 @@ class InputDecoration {
...
@@ -2300,7 +2354,7 @@ class InputDecoration {
///
///
/// By default the fillColor is based on the current [Theme].
/// By default the fillColor is based on the current [Theme].
///
///
/// The decoration's container is the area which is filled if [
isF
illed] is
/// The decoration's container is the area which is filled if [
f
illed] is
/// true and bordered per the [border]. It's the area adjacent to
/// true and bordered per the [border]. It's the area adjacent to
/// [decoration.icon] and above the widgets that contain [helperText],
/// [decoration.icon] and above the widgets that contain [helperText],
/// [errorText], and [counterText].
/// [errorText], and [counterText].
...
@@ -2432,7 +2486,7 @@ class InputDecoration {
...
@@ -2432,7 +2486,7 @@ class InputDecoration {
/// a given state, all four borders – [errorBorder], [focusedBorder],
/// a given state, all four borders – [errorBorder], [focusedBorder],
/// [enabledBorder], [disabledBorder] – must be set.
/// [enabledBorder], [disabledBorder] – must be set.
///
///
/// The decoration's container is the area which is filled if [
isF
illed] is
/// The decoration's container is the area which is filled if [
f
illed] is
/// true and bordered per the [border]. It's the area adjacent to
/// true and bordered per the [border]. It's the area adjacent to
/// [InputDecoration.icon] and above the widgets that contain
/// [InputDecoration.icon] and above the widgets that contain
/// [InputDecoration.helperText], [InputDecoration.errorText], and
/// [InputDecoration.helperText], [InputDecoration.errorText], and
...
@@ -2446,7 +2500,7 @@ class InputDecoration {
...
@@ -2446,7 +2500,7 @@ class InputDecoration {
/// is not specified. This border's [InputBorder.borderSide] property is
/// is not specified. This border's [InputBorder.borderSide] property is
/// configured by the InputDecorator, depending on the values of
/// configured by the InputDecorator, depending on the values of
/// [InputDecoration.errorText], [InputDecoration.enabled],
/// [InputDecoration.errorText], [InputDecoration.enabled],
/// [InputDecorator.isFocused and the current [Theme].
/// [InputDecorator.isFocused
]
and the current [Theme].
///
///
/// Typically one of [UnderlineInputBorder] or [OutlineInputBorder].
/// Typically one of [UnderlineInputBorder] or [OutlineInputBorder].
/// If null, InputDecorator's default is `const UnderlineInputBorder()`.
/// If null, InputDecorator's default is `const UnderlineInputBorder()`.
...
@@ -2637,8 +2691,8 @@ class InputDecoration {
...
@@ -2637,8 +2691,8 @@ class InputDecoration {
@override
@override
int
get
hashCode
{
int
get
hashCode
{
// Split into
multiple hashValues call
s
// Split into
two hashValues calls because the hashValues function i
s
//
because the hashValues function is
limited to 20 parameters.
// limited to 20 parameters.
return
hashValues
(
return
hashValues
(
icon
,
icon
,
labelText
,
labelText
,
...
@@ -2653,22 +2707,20 @@ class InputDecoration {
...
@@ -2653,22 +2707,20 @@ class InputDecoration {
errorMaxLines
,
errorMaxLines
,
hasFloatingPlaceholder
,
hasFloatingPlaceholder
,
isDense
,
isDense
,
contentPadding
,
isCollapsed
,
filled
,
fillColor
,
border
,
enabled
,
prefixIcon
,
hashValues
(
hashValues
(
contentPadding
,
isCollapsed
,
filled
,
fillColor
,
border
,
enabled
,
prefixIcon
,
prefix
,
prefix
,
prefixText
,
prefixText
,
prefixStyle
,
prefixStyle
,
suffixIcon
,
suffixIcon
,
suffix
,
suffix
,
suffixText
,
suffixText
,
),
hashValues
(
suffixStyle
,
suffixStyle
,
counterText
,
counterText
,
counterStyle
,
counterStyle
,
...
@@ -2774,7 +2826,7 @@ class InputDecorationTheme extends Diagnosticable {
...
@@ -2774,7 +2826,7 @@ class InputDecorationTheme extends Diagnosticable {
/// Creates a value for [ThemeData.inputDecorationTheme] that
/// Creates a value for [ThemeData.inputDecorationTheme] that
/// defines default values for [InputDecorator].
/// defines default values for [InputDecorator].
///
///
/// The values of [isDense], [isCollapsed], [
isF
illed], and [border] must
/// The values of [isDense], [isCollapsed], [
f
illed], and [border] must
/// not be null.
/// not be null.
const
InputDecorationTheme
({
const
InputDecorationTheme
({
this
.
labelStyle
,
this
.
labelStyle
,
...
@@ -2860,7 +2912,7 @@ class InputDecorationTheme extends Diagnosticable {
...
@@ -2860,7 +2912,7 @@ class InputDecorationTheme extends Diagnosticable {
/// The padding for the input decoration's container.
/// The padding for the input decoration's container.
///
///
/// The decoration's container is the area which is filled if
/// The decoration's container is the area which is filled if
/// [InputDecoration.
isF
illed] is true and bordered per the [border].
/// [InputDecoration.
f
illed] is true and bordered per the [border].
/// It's the area adjacent to [InputDecoration.icon] and above the
/// It's the area adjacent to [InputDecoration.icon] and above the
/// [InputDecoration.icon] and above the widgets that contain
/// [InputDecoration.icon] and above the widgets that contain
/// [InputDecoration.helperText], [InputDecoration.errorText], and
/// [InputDecoration.helperText], [InputDecoration.errorText], and
...
@@ -2894,11 +2946,11 @@ class InputDecorationTheme extends Diagnosticable {
...
@@ -2894,11 +2946,11 @@ class InputDecorationTheme extends Diagnosticable {
/// If true the decoration's container is filled with [fillColor].
/// If true the decoration's container is filled with [fillColor].
///
///
/// Typically this field set to true if [border] is
/// Typically this field set to true if [border] is
an
/// [
const UnderlineInputBorder()
].
/// [
UnderlineInputBorder
].
///
///
/// The decoration's container is the area, defined by the border's
/// The decoration's container is the area, defined by the border's
/// [InputBorder.getOuterPath], which is filled if [
isF
illed] is
/// [InputBorder.getOuterPath], which is filled if [
f
illed] is
/// true and bordered per the [border].
/// true and bordered per the [border].
///
///
/// This property is false by default.
/// This property is false by default.
...
@@ -2909,7 +2961,7 @@ class InputDecorationTheme extends Diagnosticable {
...
@@ -2909,7 +2961,7 @@ class InputDecorationTheme extends Diagnosticable {
/// By default the fillColor is based on the current [Theme].
/// By default the fillColor is based on the current [Theme].
///
///
/// The decoration's container is the area, defined by the border's
/// The decoration's container is the area, defined by the border's
/// [InputBorder.getOuterPath], which is filled if [
isF
illed] is
/// [InputBorder.getOuterPath], which is filled if [
f
illed] is
/// true and bordered per the [border].
/// true and bordered per the [border].
final
Color
fillColor
;
final
Color
fillColor
;
...
@@ -3033,7 +3085,7 @@ class InputDecorationTheme extends Diagnosticable {
...
@@ -3033,7 +3085,7 @@ class InputDecorationTheme extends Diagnosticable {
/// The shape of the border to draw around the decoration's container.
/// The shape of the border to draw around the decoration's container.
///
///
/// The decoration's container is the area which is filled if [
isF
illed] is
/// The decoration's container is the area which is filled if [
f
illed] is
/// true and bordered per the [border]. It's the area adjacent to
/// true and bordered per the [border]. It's the area adjacent to
/// [InputDecoration.icon] and above the widgets that contain
/// [InputDecoration.icon] and above the widgets that contain
/// [InputDecoration.helperText], [InputDecoration.errorText], and
/// [InputDecoration.helperText], [InputDecoration.errorText], and
...
@@ -3047,7 +3099,7 @@ class InputDecorationTheme extends Diagnosticable {
...
@@ -3047,7 +3099,7 @@ class InputDecorationTheme extends Diagnosticable {
/// is not specified. This border's [InputBorder.borderSide] property is
/// is not specified. This border's [InputBorder.borderSide] property is
/// configured by the InputDecorator, depending on the values of
/// configured by the InputDecorator, depending on the values of
/// [InputDecoration.errorText], [InputDecoration.enabled],
/// [InputDecoration.errorText], [InputDecoration.enabled],
/// [InputDecorator.isFocused and the current [Theme].
/// [InputDecorator.isFocused
]
and the current [Theme].
///
///
/// Typically one of [UnderlineInputBorder] or [OutlineInputBorder].
/// Typically one of [UnderlineInputBorder] or [OutlineInputBorder].
/// If null, InputDecorator's default is `const UnderlineInputBorder()`.
/// If null, InputDecorator's default is `const UnderlineInputBorder()`.
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment