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
139a4d39
Unverified
Commit
139a4d39
authored
Dec 15, 2021
by
Taha Tesser
Committed by
GitHub
Dec 15, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add `CupertinoDatePicker` Interactive Example (#93509)
parent
41096177
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
263 additions
and
0 deletions
+263
-0
cupertino_date_picker.0.dart
...pi/lib/cupertino/date_picker/cupertino_date_picker.0.dart
+186
-0
cupertino_date_picker.0_test.dart
...t/cupertino/date_picker/cupertino_date_picker.0_test.dart
+67
-0
date_picker.dart
packages/flutter/lib/src/cupertino/date_picker.dart
+10
-0
No files found.
examples/api/lib/cupertino/date_picker/cupertino_date_picker.0.dart
0 → 100644
View file @
139a4d39
// Copyright 2014 The Flutter Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Flutter code sample for CupertinoDatePicker
import
'package:flutter/cupertino.dart'
;
void
main
(
)
=>
runApp
(
const
MyApp
());
class
MyApp
extends
StatelessWidget
{
const
MyApp
({
Key
?
key
})
:
super
(
key:
key
);
static
const
String
_title
=
'Flutter Code Sample'
;
@override
Widget
build
(
BuildContext
context
)
{
return
const
CupertinoApp
(
title:
_title
,
home:
MyStatelessWidget
(),
);
}
}
class
MyStatelessWidget
extends
StatefulWidget
{
const
MyStatelessWidget
({
Key
?
key
})
:
super
(
key:
key
);
@override
State
<
MyStatelessWidget
>
createState
()
=>
_MyStatelessWidgetState
();
}
class
_MyStatelessWidgetState
extends
State
<
MyStatelessWidget
>
{
DateTime
date
=
DateTime
(
2016
,
10
,
26
);
DateTime
time
=
DateTime
(
2016
,
5
,
10
,
22
,
35
);
DateTime
dateTime
=
DateTime
(
2016
,
8
,
3
,
17
,
45
);
// This shows a CupertinoModalPopup with a reasonable fixed height which hosts CupertinoDatePicker.
void
_showDialog
(
Widget
child
)
{
showCupertinoModalPopup
<
void
>(
context:
context
,
builder:
(
BuildContext
context
)
=>
Container
(
height:
216
,
padding:
const
EdgeInsets
.
only
(
top:
6.0
),
// The Bottom margin is provided to align the popup above the system navigation bar.
margin:
EdgeInsets
.
only
(
bottom:
MediaQuery
.
of
(
context
).
viewInsets
.
bottom
,
),
// Provide a background color for the popup.
color:
CupertinoColors
.
systemBackground
.
resolveFrom
(
context
),
// Use a SafeArea widget to avoid system overlaps.
child:
SafeArea
(
top:
false
,
child:
child
,
),
)
);
}
@override
Widget
build
(
BuildContext
context
)
{
return
CupertinoPageScaffold
(
child:
DefaultTextStyle
(
style:
TextStyle
(
color:
CupertinoColors
.
label
.
resolveFrom
(
context
),
fontSize:
22.0
,
),
child:
Center
(
child:
Column
(
mainAxisAlignment:
MainAxisAlignment
.
center
,
children:
<
Widget
>[
_DatePickerItem
(
children:
<
Widget
>[
const
Text
(
'Date'
),
CupertinoButton
(
// Display a CupertinoDatePicker in date picker mode.
onPressed:
()
=>
_showDialog
(
CupertinoDatePicker
(
initialDateTime:
date
,
mode:
CupertinoDatePickerMode
.
date
,
use24hFormat:
true
,
// This is called when the user changes the date.
onDateTimeChanged:
(
DateTime
newDate
)
{
setState
(()
=>
date
=
newDate
);
},
),
),
// In this example, the date value is formatted manually. You can use intl package
// to format the value based on user's locale settings.
child:
Text
(
'
${date.month}
-
${date.day}
-
${date.year}
'
,
style:
const
TextStyle
(
fontSize:
22.0
,
),
),
),
],
),
_DatePickerItem
(
children:
<
Widget
>[
const
Text
(
'Time'
),
CupertinoButton
(
// Display a CupertinoDatePicker in time picker mode.
onPressed:
()
=>
_showDialog
(
CupertinoDatePicker
(
initialDateTime:
time
,
mode:
CupertinoDatePickerMode
.
time
,
use24hFormat:
true
,
// This is called when the user changes the time.
onDateTimeChanged:
(
DateTime
newTime
)
{
setState
(()
=>
time
=
newTime
);
},
),
),
// In this example, the time value is formatted manually. You can use intl package to
// format the value based on the user's locale settings.
child:
Text
(
'
${time.hour}
:
${time.minute}
'
,
style:
const
TextStyle
(
fontSize:
22.0
,
),
),
),
],
),
_DatePickerItem
(
children:
<
Widget
>[
const
Text
(
'DateTime'
),
CupertinoButton
(
// Display a CupertinoDatePicker in dateTime picker mode.
onPressed:
()
=>
_showDialog
(
CupertinoDatePicker
(
initialDateTime:
dateTime
,
use24hFormat:
true
,
// This is called when the user changes the dateTime.
onDateTimeChanged:
(
DateTime
newDateTime
)
{
setState
(()
=>
dateTime
=
newDateTime
);
},
),
),
// In this example, time value is formatted manually. You can use intl package to
// format the value based on the user's locale settings.
child:
Text
(
'
${dateTime.month}
-
${dateTime.day}
-
${dateTime.year}
${dateTime.hour}
:
${dateTime.minute}
'
,
style:
const
TextStyle
(
fontSize:
22.0
,
),
),
),
],
),
],
),
),
),
);
}
}
// This class simply decorates a row of widgets.
class
_DatePickerItem
extends
StatelessWidget
{
const
_DatePickerItem
({
required
this
.
children
});
final
List
<
Widget
>
children
;
@override
Widget
build
(
BuildContext
context
)
{
return
DecoratedBox
(
decoration:
const
BoxDecoration
(
border:
Border
(
top:
BorderSide
(
color:
CupertinoColors
.
inactiveGray
,
width:
0.0
,
),
bottom:
BorderSide
(
color:
CupertinoColors
.
inactiveGray
,
width:
0.0
,
),
),
),
child:
Padding
(
padding:
const
EdgeInsets
.
symmetric
(
horizontal:
16.0
),
child:
Row
(
mainAxisAlignment:
MainAxisAlignment
.
spaceBetween
,
children:
children
,
),
),
);
}
}
examples/api/test/cupertino/date_picker/cupertino_date_picker.0_test.dart
0 → 100644
View file @
139a4d39
// Copyright 2014 The Flutter Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import
'package:flutter_api_samples/cupertino/date_picker/cupertino_date_picker.0.dart'
as
example
;
import
'package:flutter_test/flutter_test.dart'
;
const
Offset
_kRowOffset
=
Offset
(
0.0
,
-
50.0
);
void
main
(
)
{
testWidgets
(
'Can change date, time and dateTime using CupertinoDatePicker'
,
(
WidgetTester
tester
)
async
{
await
tester
.
pumpWidget
(
const
example
.
MyApp
(),
);
// Open the date picker.
await
tester
.
tap
(
find
.
text
(
'10-26-2016'
));
await
tester
.
pumpAndSettle
();
// Drag month, day and year wheels to change the picked date.
await
tester
.
drag
(
find
.
text
(
'October'
),
_kRowOffset
,
touchSlopY:
0
,
warnIfMissed:
false
);
// see top of file
await
tester
.
drag
(
find
.
text
(
'26'
),
_kRowOffset
,
touchSlopY:
0
,
warnIfMissed:
false
);
// see top of file
await
tester
.
drag
(
find
.
text
(
'2016'
),
_kRowOffset
,
touchSlopY:
0
,
warnIfMissed:
false
);
// see top of file
await
tester
.
pump
();
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
// Close the date picker.
await
tester
.
tapAt
(
const
Offset
(
1.0
,
1.0
));
await
tester
.
pumpAndSettle
();
expect
(
find
.
text
(
'12-28-2018'
),
findsOneWidget
);
// Open the time picker.
await
tester
.
tap
(
find
.
text
(
'22:35'
));
await
tester
.
pumpAndSettle
();
// Drag hour and minute wheels to change the picked time.
await
tester
.
drag
(
find
.
text
(
'22'
),
const
Offset
(
0.0
,
50.0
),
touchSlopY:
0
,
warnIfMissed:
false
);
// see top of file
await
tester
.
drag
(
find
.
text
(
'35'
),
const
Offset
(
0.0
,
50.0
),
touchSlopY:
0
,
warnIfMissed:
false
);
// see top of file
await
tester
.
pump
();
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
// Close the time picker.
await
tester
.
tapAt
(
const
Offset
(
1.0
,
1.0
));
await
tester
.
pumpAndSettle
();
expect
(
find
.
text
(
'20:33'
),
findsOneWidget
);
// Open the dateTime picker.
await
tester
.
tap
(
find
.
text
(
'8-3-2016 17:45'
));
await
tester
.
pumpAndSettle
();
// Drag hour and minute wheels to change the picked time.
await
tester
.
drag
(
find
.
text
(
'17'
),
const
Offset
(
0.0
,
50.0
),
touchSlopY:
0
,
warnIfMissed:
false
);
// see top of file
await
tester
.
drag
(
find
.
text
(
'45'
),
const
Offset
(
0.0
,
50.0
),
touchSlopY:
0
,
warnIfMissed:
false
);
// see top of file
await
tester
.
pump
();
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
// Close the dateTime picker.
await
tester
.
tapAt
(
const
Offset
(
1.0
,
1.0
));
await
tester
.
pumpAndSettle
();
expect
(
find
.
text
(
'8-3-2016 15:43'
),
findsOneWidget
);
});
}
packages/flutter/lib/src/cupertino/date_picker.dart
View file @
139a4d39
...
@@ -202,6 +202,16 @@ enum _PickerColumnType {
...
@@ -202,6 +202,16 @@ enum _PickerColumnType {
/// full screen width. Content texts are shown with
/// full screen width. Content texts are shown with
/// [CupertinoTextThemeData.dateTimePickerTextStyle].
/// [CupertinoTextThemeData.dateTimePickerTextStyle].
///
///
/// {@tool dartpad}
/// This sample shows how to implement CupertinoDatePicker with different picker modes.
/// We can provide intiial dateTime value for the picker to display. When user changes
/// the drag the date or time wheels, the picker will call onDateTimeChanged callback.
///
/// CupertinoDatePicker can be displayed directly on a screen or in a popup.
///
/// ** See code in examples/api/lib/cupertino/date_picker/cupertino_date_picker.0.dart **
/// {@end-tool}
///
/// See also:
/// See also:
///
///
/// * [CupertinoTimerPicker], the class that implements the iOS-style timer picker.
/// * [CupertinoTimerPicker], the class that implements the iOS-style timer picker.
...
...
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