-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.dart
92 lines (86 loc) · 2.52 KB
/
main.dart
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
import 'package:flutter/material.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatelessWidget {
const MyApp({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Date Picker',
debugShowCheckedModeBanner: false,
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: const MyHomePage(title: 'Date Picker'),
);
}
}
class MyHomePage extends StatefulWidget {
const MyHomePage({Key? key, required this.title}) : super(key: key);
final String title;
@override
State<MyHomePage> createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
String date = "";
DateTime selectedDate = DateTime.now();
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
backgroundColor: const Color.fromARGB(255, 25, 42, 97),
),
backgroundColor: Colors.white,
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
ElevatedButton.icon(
onPressed: () {
selectDate(context);
},
icon: const Icon(Icons.calendar_month),
style: ButtonStyle(
backgroundColor:
MaterialStateProperty.all<Color>(Colors.pink),
padding: MaterialStateProperty.all(
const EdgeInsets.fromLTRB(14, 14, 14, 14)),
),
label: const Text(
"Choose Date",
style: TextStyle(
color: Colors.white,
),
)),
const VerticalDivider(
indent: 8,
color: Colors.white,
),
Text(
"${selectedDate.day.toString().padLeft(2, '0')}/${selectedDate.month.toString().padLeft(2, '0')}/${selectedDate.year}",
style: const TextStyle(
fontSize: 16,
fontWeight: FontWeight.bold,
),
)
],
),
),
);
}
selectDate(BuildContext context) async {
final DateTime? selected = await showDatePicker(
context: context,
initialDate: selectedDate,
firstDate: DateTime(2000),
lastDate: DateTime(2074),
);
if (selected != null && selected != selectedDate) {
setState(() {
selectedDate = selected;
});
}
}
}