month_year_picker 0.4.0+1 month_year_picker: ^0.4.0+1 copied to clipboard
The month year picker inspired by the Flutter's date picker design.
import 'package:flutter/material.dart';
import 'package:flutter_localizations/flutter_localizations.dart';
import 'package:intl/intl.dart';
import 'package:month_year_picker/month_year_picker.dart';
void main() {
runApp(const ExampleApp());
}
class ExampleApp extends StatelessWidget {
// ------------------------------- CONSTRUCTORS ------------------------------
const ExampleApp({
super.key,
});
// --------------------------------- METHODS ---------------------------------
@override
Widget build(BuildContext context) {
return const MaterialApp(
title: 'Month Year Picker Example',
home: MyHomePage(),
localizationsDelegates: [
GlobalWidgetsLocalizations.delegate,
GlobalMaterialLocalizations.delegate,
MonthYearPickerLocalizations.delegate,
],
);
}
}
class MyHomePage extends StatefulWidget {
// ------------------------------- CONSTRUCTORS ------------------------------
const MyHomePage({
super.key,
});
// --------------------------------- METHODS ---------------------------------
@override
State<MyHomePage> createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
// ---------------------------------- FIELDS ---------------------------------
DateTime? _selected;
// --------------------------------- METHODS ---------------------------------
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: const Text('Month Year Picker Example')),
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
if (_selected == null)
const Text('No month year selected.')
else
Text(DateFormat().add_yM().format(_selected!)),
TextButton(
child: const Text('DEFAULT LOCALE'),
onPressed: () async => _onPressed(context: context),
),
TextButton(
child: const Text('BAHASA MALAYSIA'),
onPressed: () async => _onPressed(context: context, locale: 'ms'),
),
TextButton(
child: const Text('اللغة العربية'),
onPressed: () async => _onPressed(context: context, locale: 'ar'),
),
],
),
),
);
}
Future<void> _onPressed({
required BuildContext context,
String? locale,
}) async {
final localeObj = locale != null ? Locale(locale) : null;
final selected = await showMonthYearPicker(
context: context,
initialDate: _selected ?? DateTime.now(),
firstDate: DateTime(2019),
lastDate: DateTime(2030),
locale: localeObj,
);
// final selected = await showDatePicker(
// context: context,
// initialDate: _selected ?? DateTime.now(),
// firstDate: DateTime(2019),
// lastDate: DateTime(2022),
// locale: localeObj,
// );
if (selected != null) {
setState(() {
_selected = selected;
});
}
}
}