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
4a2217b3
Unverified
Commit
4a2217b3
authored
Mar 19, 2018
by
Ian Hickson
Committed by
GitHub
Mar 19, 2018
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improve documentation regarding padding for dialogs. (#15399)
parent
28352c3f
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
65 additions
and
18 deletions
+65
-18
dialog.dart
packages/flutter/lib/src/material/dialog.dart
+65
-18
No files found.
packages/flutter/lib/src/material/dialog.dart
View file @
4a2217b3
...
@@ -155,14 +155,19 @@ class AlertDialog extends StatelessWidget {
...
@@ -155,14 +155,19 @@ class AlertDialog extends StatelessWidget {
/// Creates an alert dialog.
/// Creates an alert dialog.
///
///
/// Typically used in conjunction with [showDialog].
/// Typically used in conjunction with [showDialog].
///
/// The [contentPadding] must not be null. The [titlePadding] defaults to
/// null, which implies a default that depends on the values of the other
/// properties. See the documentation of [titlePadding] for details.
const
AlertDialog
({
const
AlertDialog
({
Key
key
,
Key
key
,
this
.
title
,
this
.
title
,
this
.
titlePadding
,
this
.
titlePadding
,
this
.
content
,
this
.
content
,
this
.
contentPadding
,
this
.
contentPadding
:
const
EdgeInsets
.
fromLTRB
(
24.0
,
20.0
,
24.0
,
24.0
),
this
.
actions
this
.
actions
,
})
:
super
(
key:
key
);
})
:
assert
(
contentPadding
!=
null
),
super
(
key:
key
);
/// The (optional) title of the dialog is displayed in a large font at the top
/// The (optional) title of the dialog is displayed in a large font at the top
/// of the dialog.
/// of the dialog.
...
@@ -172,8 +177,14 @@ class AlertDialog extends StatelessWidget {
...
@@ -172,8 +177,14 @@ class AlertDialog extends StatelessWidget {
/// Padding around the title.
/// Padding around the title.
///
///
/// Uses material design default if none is supplied. If there is no title, no
/// If there is no title, no padding will be provided. Otherwise, this padding
/// padding will be provided.
/// is used.
///
/// This property defaults to providing 24 pixels on the top, left, and right
/// of the title. If the [content] is not null, then no bottom padding is
/// provided (but see [contentPadding]). If it _is_ null, then an extra 20
/// pixels of bottom padding is added to separate the [title] from the
/// [actions].
final
EdgeInsetsGeometry
titlePadding
;
final
EdgeInsetsGeometry
titlePadding
;
/// The (optional) content of the dialog is displayed in the center of the
/// The (optional) content of the dialog is displayed in the center of the
...
@@ -186,7 +197,10 @@ class AlertDialog extends StatelessWidget {
...
@@ -186,7 +197,10 @@ class AlertDialog extends StatelessWidget {
/// Padding around the content.
/// Padding around the content.
///
///
/// Uses material design default if none is supplied.
/// If there is no content, no padding will be provided. Otherwise, padding of
/// 20 pixels is provided above the content to separate the content from the
/// title, and padding of 24 pixels is provided on the left, right, and bottom
/// to separate the content from the other edges of the dialog.
final
EdgeInsetsGeometry
contentPadding
;
final
EdgeInsetsGeometry
contentPadding
;
/// The (optional) set of actions that are displayed at the bottom of the
/// The (optional) set of actions that are displayed at the bottom of the
...
@@ -194,7 +208,12 @@ class AlertDialog extends StatelessWidget {
...
@@ -194,7 +208,12 @@ class AlertDialog extends StatelessWidget {
///
///
/// Typically this is a list of [FlatButton] widgets.
/// Typically this is a list of [FlatButton] widgets.
///
///
/// These widgets will be wrapped in a [ButtonBar].
/// These widgets will be wrapped in a [ButtonBar], which introduces 8 pixels
/// of padding on each side.
///
/// If the [title] is not null but the [content] _is_ null, then an extra 20
/// pixels of padding is added above the [ButtonBar] to separate the [title]
/// from the [actions].
final
List
<
Widget
>
actions
;
final
List
<
Widget
>
actions
;
@override
@override
...
@@ -203,7 +222,7 @@ class AlertDialog extends StatelessWidget {
...
@@ -203,7 +222,7 @@ class AlertDialog extends StatelessWidget {
if
(
title
!=
null
)
{
if
(
title
!=
null
)
{
children
.
add
(
new
Padding
(
children
.
add
(
new
Padding
(
padding:
titlePadding
??
new
EdgeInsets
Directional
.
fromSTE
B
(
24.0
,
24.0
,
24.0
,
content
==
null
?
20.0
:
0.0
),
padding:
titlePadding
??
new
EdgeInsets
.
fromLTR
B
(
24.0
,
24.0
,
24.0
,
content
==
null
?
20.0
:
0.0
),
child:
new
DefaultTextStyle
(
child:
new
DefaultTextStyle
(
style:
Theme
.
of
(
context
).
textTheme
.
title
,
style:
Theme
.
of
(
context
).
textTheme
.
title
,
child:
title
,
child:
title
,
...
@@ -214,7 +233,7 @@ class AlertDialog extends StatelessWidget {
...
@@ -214,7 +233,7 @@ class AlertDialog extends StatelessWidget {
if
(
content
!=
null
)
{
if
(
content
!=
null
)
{
children
.
add
(
new
Flexible
(
children
.
add
(
new
Flexible
(
child:
new
Padding
(
child:
new
Padding
(
padding:
contentPadding
??
const
EdgeInsetsDirectional
.
fromSTEB
(
24.0
,
20.0
,
24.0
,
24.0
)
,
padding:
contentPadding
,
child:
new
DefaultTextStyle
(
child:
new
DefaultTextStyle
(
style:
Theme
.
of
(
context
).
textTheme
.
subhead
,
style:
Theme
.
of
(
context
).
textTheme
.
subhead
,
child:
content
,
child:
content
,
...
@@ -250,6 +269,12 @@ class AlertDialog extends StatelessWidget {
...
@@ -250,6 +269,12 @@ class AlertDialog extends StatelessWidget {
/// selects this option, the widget will call the [onPressed] callback, which
/// selects this option, the widget will call the [onPressed] callback, which
/// typically uses [Navigator.pop] to close the dialog.
/// typically uses [Navigator.pop] to close the dialog.
///
///
/// The padding on a [SimpleDialogOption] is configured to combine with the
/// default [SimpleDialog.contentPadding] so that each option ends up 8 pixels
/// from the other vertically, with 20 pixels of spacing between the dialog's
/// title and the first option, and 24 pixels of spacing between the last option
/// and the bottom of the dialog.
///
/// ## Sample code
/// ## Sample code
///
///
/// ```dart
/// ```dart
...
@@ -304,6 +329,10 @@ class SimpleDialogOption extends StatelessWidget {
...
@@ -304,6 +329,10 @@ class SimpleDialogOption extends StatelessWidget {
/// A simple dialog offers the user a choice between several options. A simple
/// A simple dialog offers the user a choice between several options. A simple
/// dialog has an optional title that is displayed above the choices.
/// dialog has an optional title that is displayed above the choices.
///
///
/// Choices are normally represented using [SimpleDialogOption] widgets. If
/// other widgets are used, see [contentPadding] for notes regarding the
/// conventions for obtaining the spacing expected by Material Design.
///
/// For dialogs that inform the user about a situation, consider using an
/// For dialogs that inform the user about a situation, consider using an
/// [AlertDialog].
/// [AlertDialog].
///
///
...
@@ -365,13 +394,17 @@ class SimpleDialog extends StatelessWidget {
...
@@ -365,13 +394,17 @@ class SimpleDialog extends StatelessWidget {
/// Creates a simple dialog.
/// Creates a simple dialog.
///
///
/// Typically used in conjunction with [showDialog].
/// Typically used in conjunction with [showDialog].
///
/// The [titlePadding] and [contentPadding] arguments must not be null.
const
SimpleDialog
({
const
SimpleDialog
({
Key
key
,
Key
key
,
this
.
title
,
this
.
title
,
this
.
titlePadding
,
this
.
titlePadding
:
const
EdgeInsets
.
fromLTRB
(
24.0
,
24.0
,
24.0
,
0.0
)
,
this
.
children
,
this
.
children
,
this
.
contentPadding
,
this
.
contentPadding
:
const
EdgeInsets
.
fromLTRB
(
0.0
,
12.0
,
0.0
,
16.0
),
})
:
super
(
key:
key
);
})
:
assert
(
titlePadding
!=
null
),
assert
(
contentPadding
!=
null
),
super
(
key:
key
);
/// The (optional) title of the dialog is displayed in a large font at the top
/// The (optional) title of the dialog is displayed in a large font at the top
/// of the dialog.
/// of the dialog.
...
@@ -381,8 +414,13 @@ class SimpleDialog extends StatelessWidget {
...
@@ -381,8 +414,13 @@ class SimpleDialog extends StatelessWidget {
/// Padding around the title.
/// Padding around the title.
///
///
/// Uses material design default if none is supplied. If there is no title, no
/// If there is no title, no padding will be provided.
/// padding will be provided.
///
/// By default, this provides the recommend Material Design padding of 24
/// pixels around the left, top, and right edges of the title.
///
/// See [contentPadding] for the conventions regarding padding between the
/// [title] and the [children].
final
EdgeInsetsGeometry
titlePadding
;
final
EdgeInsetsGeometry
titlePadding
;
/// The (optional) content of the dialog is displayed in a
/// The (optional) content of the dialog is displayed in a
...
@@ -393,7 +431,16 @@ class SimpleDialog extends StatelessWidget {
...
@@ -393,7 +431,16 @@ class SimpleDialog extends StatelessWidget {
/// Padding around the content.
/// Padding around the content.
///
///
/// Uses material design default if none is supplied.
/// By default, this is 12 pixels on the top and 16 pixels on the bottom. This
/// is intended to be combined with children that have 24 pixels of padding on
/// the left and right, and 8 pixels of padding on the top and bottom, so that
/// the content ends up being indented 20 pixels from the title, 24 pixels
/// from the bottom, and 24 pixels from the sides.
///
/// The [SimpleDialogOption] widget uses such padding.
///
/// If there is no [title], the [contentPadding] should be adjusted so that
/// the top padding ends up being 24 pixels.
final
EdgeInsetsGeometry
contentPadding
;
final
EdgeInsetsGeometry
contentPadding
;
@override
@override
...
@@ -402,10 +449,10 @@ class SimpleDialog extends StatelessWidget {
...
@@ -402,10 +449,10 @@ class SimpleDialog extends StatelessWidget {
if
(
title
!=
null
)
{
if
(
title
!=
null
)
{
body
.
add
(
new
Padding
(
body
.
add
(
new
Padding
(
padding:
titlePadding
??
const
EdgeInsetsDirectional
.
fromSTEB
(
24.0
,
24.0
,
24.0
,
0.0
)
,
padding:
titlePadding
,
child:
new
DefaultTextStyle
(
child:
new
DefaultTextStyle
(
style:
Theme
.
of
(
context
).
textTheme
.
title
,
style:
Theme
.
of
(
context
).
textTheme
.
title
,
child:
title
child:
title
,
)
)
));
));
}
}
...
@@ -413,7 +460,7 @@ class SimpleDialog extends StatelessWidget {
...
@@ -413,7 +460,7 @@ class SimpleDialog extends StatelessWidget {
if
(
children
!=
null
)
{
if
(
children
!=
null
)
{
body
.
add
(
new
Flexible
(
body
.
add
(
new
Flexible
(
child:
new
SingleChildScrollView
(
child:
new
SingleChildScrollView
(
padding:
contentPadding
??
const
EdgeInsetsDirectional
.
fromSTEB
(
0.0
,
12.0
,
0.0
,
16.0
)
,
padding:
contentPadding
,
child:
new
ListBody
(
children:
children
),
child:
new
ListBody
(
children:
children
),
)
)
));
));
...
...
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