From 439ae5bd5a1a7ed0aef481630fdd6e98f049b43b Mon Sep 17 00:00:00 2001 From: Chen Peng Date: Fri, 14 Jun 2024 10:19:11 +0800 Subject: [PATCH] [flutter_web] Form_showDatePicker --- notes/flutter_web/lib/assets.g.dart | 2 + .../_examples/Form_CalendarDatePicker.dart | 32 +++++++++++++++ .../_examples/Form_showDatePicker.dart | 39 +++++++++++++++++++ .../notes/cheatsheets/widgets/page.dart | 37 ++---------------- 4 files changed, 77 insertions(+), 33 deletions(-) create mode 100644 notes/flutter_web/lib/routes/notes/cheatsheets/widgets/_examples/Form_CalendarDatePicker.dart create mode 100644 notes/flutter_web/lib/routes/notes/cheatsheets/widgets/_examples/Form_showDatePicker.dart diff --git a/notes/flutter_web/lib/assets.g.dart b/notes/flutter_web/lib/assets.g.dart index e314f28d..9a009777 100644 --- a/notes/flutter_web/lib/assets.g.dart +++ b/notes/flutter_web/lib/assets.g.dart @@ -109,6 +109,8 @@ mixin AssetsMixin { final Asset lib_routes_notes_cheatsheets_widgets__examples_Form_ChoiceChip_dart = Asset('lib/routes/notes/cheatsheets/widgets/_examples/Form_ChoiceChip.dart'); final Asset lib_routes_notes_cheatsheets_widgets__examples_Form_Checkbox_dart = Asset('lib/routes/notes/cheatsheets/widgets/_examples/Form_Checkbox.dart'); final Asset lib_routes_notes_cheatsheets_widgets__examples_Form_showDateRangePicker_dart = Asset('lib/routes/notes/cheatsheets/widgets/_examples/Form_showDateRangePicker.dart'); + final Asset lib_routes_notes_cheatsheets_widgets__examples_Form_CalendarDatePicker_dart = Asset('lib/routes/notes/cheatsheets/widgets/_examples/Form_CalendarDatePicker.dart'); + final Asset lib_routes_notes_cheatsheets_widgets__examples_Form_showDatePicker_dart = Asset('lib/routes/notes/cheatsheets/widgets/_examples/Form_showDatePicker.dart'); final Asset lib_routes_notes_cheatsheets_widgets__examples_Navigation_SliverAppBar_dart = Asset('lib/routes/notes/cheatsheets/widgets/_examples/Navigation_SliverAppBar.dart'); final Asset lib_routes_notes_cheatsheets_widgets__examples_LayoutCore_ContainerCell_dart = Asset('lib/routes/notes/cheatsheets/widgets/_examples/LayoutCore_ContainerCell.dart'); final Asset lib_routes_notes_cheatsheets_widgets__examples_Navigation_AppBar_dart = Asset('lib/routes/notes/cheatsheets/widgets/_examples/Navigation_AppBar.dart'); diff --git a/notes/flutter_web/lib/routes/notes/cheatsheets/widgets/_examples/Form_CalendarDatePicker.dart b/notes/flutter_web/lib/routes/notes/cheatsheets/widgets/_examples/Form_CalendarDatePicker.dart new file mode 100644 index 00000000..95ff9209 --- /dev/null +++ b/notes/flutter_web/lib/routes/notes/cheatsheets/widgets/_examples/Form_CalendarDatePicker.dart @@ -0,0 +1,32 @@ +import 'package:flutter/material.dart'; +import 'package:you_flutter/state.dart'; + +main() { + runApp(MaterialApp(home: Scaffold(body: Form_CalendarDatePicker()))); +} + +// ignore: camel_case_types +class Form_CalendarDatePicker extends StatelessWidget { + Form_CalendarDatePicker({super.key}); + + final Value date = (null as DateTime?).signal(); + + @override + Widget build(BuildContext context) { + return Watch( + builder: (context) { + return Column( + children: [ + Text("date: ${date.value}"), + CalendarDatePicker( + initialDate: DateTime.now(), + firstDate: DateTime(DateTime.now().year - 1), + lastDate: DateTime(DateTime.now().year + 1), + onDateChanged: (value) => date.value = value, + ), + ], + ); + }, + ); + } +} diff --git a/notes/flutter_web/lib/routes/notes/cheatsheets/widgets/_examples/Form_showDatePicker.dart b/notes/flutter_web/lib/routes/notes/cheatsheets/widgets/_examples/Form_showDatePicker.dart new file mode 100644 index 00000000..4196042f --- /dev/null +++ b/notes/flutter_web/lib/routes/notes/cheatsheets/widgets/_examples/Form_showDatePicker.dart @@ -0,0 +1,39 @@ +import 'package:flutter/material.dart'; +import 'package:you_flutter/state.dart'; + +main() { + runApp(MaterialApp(home: Scaffold(body: Form_showDatePicker()))); +} + +// ignore: camel_case_types +class Form_showDatePicker extends StatelessWidget { + Form_showDatePicker({super.key}); + + final Value date = (null as DateTime?).signal(); + + @override + Widget build(BuildContext context) { + return Watch( + builder: (context) { + return Column( + children: [ + Text("date: ${date.value}"), + TextButton.icon( + onPressed: () async { + DateTime? selected = await showDatePicker( + context: context, + initialDate: DateTime.now(), + firstDate: DateTime(DateTime.now().year - 1), + lastDate: DateTime(DateTime.now().year + 1), + ); + date.value = selected; + }, + icon: const Icon(Icons.calendar_month), + label: const Text('showDatePicker dialog'), + ), + ], + ); + }, + ); + } +} diff --git a/notes/flutter_web/lib/routes/notes/cheatsheets/widgets/page.dart b/notes/flutter_web/lib/routes/notes/cheatsheets/widgets/page.dart index d41e26de..a686b448 100644 --- a/notes/flutter_web/lib/routes/notes/cheatsheets/widgets/page.dart +++ b/notes/flutter_web/lib/routes/notes/cheatsheets/widgets/page.dart @@ -3,6 +3,7 @@ import 'package:flutter/services.dart'; import 'package:flutter_web/app.dart'; import 'package:flutter_web/routes/notes/cheatsheets/widgets/_examples/Form_ActionChip.dart'; import 'package:flutter_web/routes/notes/cheatsheets/widgets/_examples/Form_ButtonStyleButton.dart'; +import 'package:flutter_web/routes/notes/cheatsheets/widgets/_examples/Form_CalendarDatePicker.dart'; import 'package:flutter_web/routes/notes/cheatsheets/widgets/_examples/Form_Checkbox.dart'; import 'package:flutter_web/routes/notes/cheatsheets/widgets/_examples/Form_CheckboxListTile.dart'; import 'package:flutter_web/routes/notes/cheatsheets/widgets/_examples/Form_Chip.dart'; @@ -13,6 +14,7 @@ import 'package:flutter_web/routes/notes/cheatsheets/widgets/_examples/Form_Icon import 'package:flutter_web/routes/notes/cheatsheets/widgets/_examples/Form_InputChip.dart'; import 'package:flutter_web/routes/notes/cheatsheets/widgets/_examples/Form_SearchAnchor.dart'; import 'package:flutter_web/routes/notes/cheatsheets/widgets/_examples/Form_SegmentButton.dart'; +import 'package:flutter_web/routes/notes/cheatsheets/widgets/_examples/Form_showDatePicker.dart'; import 'package:flutter_web/routes/notes/cheatsheets/widgets/_examples/Form_showDateRangePicker.dart'; import 'package:flutter_web/routes/notes/cheatsheets/widgets/_examples/LayoutCore_ContainerCell.dart'; import 'package:flutter_web/routes/notes/cheatsheets/widgets/_examples/Navigation_AppBar.dart'; @@ -71,7 +73,8 @@ void build(BuildContext context, Cell print) { FlutterExample(title: "FilterChip", source: assets.lib_routes_notes_cheatsheets_widgets__examples_Form_FilterChip_dart, child: Form_FilterChip()), FlutterExample(title: "InputChip", source: assets.lib_routes_notes_cheatsheets_widgets__examples_Form_InputChip_dart, child: Form_InputChip()), FlutterExample(title: "showDateRangePicker", source: assets.lib_routes_notes_cheatsheets_widgets__examples_Form_showDateRangePicker_dart, child: Form_showDateRangePicker()), - FlutterExample(title: "datePicker", child: buttonAndInput.datePicker()), + FlutterExample(title: "showDatePicker", source: assets.lib_routes_notes_cheatsheets_widgets__examples_Form_showDatePicker_dart, child: Form_showDatePicker()), + FlutterExample(title: "CalendarDatePicker", source: assets.lib_routes_notes_cheatsheets_widgets__examples_Form_CalendarDatePicker_dart, child: Form_CalendarDatePicker()), FlutterExample(title: "timePicker", child: buttonAndInput.timePicker()), FlutterExample(title: "DropdownMenu", child: buttonAndInput.dropdownMenu()), FlutterExample(title: "Radio", child: buttonAndInput.radio()), @@ -100,38 +103,6 @@ void build(BuildContext context, Cell print) { } class ButtonAndInput { - Widget datePicker() { - final Value date = (null as DateTime?).signal(); - return Watch( - builder: (context) { - return Column( - children: [ - Text("date: ${date.value}"), - CalendarDatePicker( - initialDate: DateTime.now(), - firstDate: DateTime(DateTime.now().year - 1), - lastDate: DateTime(DateTime.now().year + 1), - onDateChanged: (value) => date.value = value, - ), - TextButton.icon( - onPressed: () async { - DateTime? selected = await showDatePicker( - context: context, - initialDate: DateTime.now(), - firstDate: DateTime(DateTime.now().year - 1), - lastDate: DateTime(DateTime.now().year + 1), - ); - date.value = selected; - }, - icon: const Icon(Icons.calendar_month), - label: const Text('showDatePicker dialog'), - ), - ], - ); - }, - ); - } - Widget timePicker() { final Value time = (null as TimeOfDay?).signal(); return Watch(