https://github.com/dylanwuzh/flutter-cupertino-date-picker
Flutter cupertino style date picker.
https://github.com/dylanwuzh/flutter-cupertino-date-picker
dart datepicker flutter
Last synced: about 1 month ago
JSON representation
Flutter cupertino style date picker.
- Host: GitHub
- URL: https://github.com/dylanwuzh/flutter-cupertino-date-picker
- Owner: dylanwuzh
- License: apache-2.0
- Created: 2018-06-21T06:52:53.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2022-09-01T08:39:28.000Z (over 2 years ago)
- Last Synced: 2025-03-30T07:18:32.767Z (about 1 month ago)
- Topics: dart, datepicker, flutter
- Language: Dart
- Size: 329 KB
- Stars: 362
- Watchers: 5
- Forks: 412
- Open Issues: 72
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Flutter Cupertino Date Picker
[[pub packages]](https://pub.dartlang.org/packages/flutter_cupertino_date_picker)
| [中文说明](./README_zh-cn.md)Flutter cupertino date picker.
![Example][1]
## Usage
#### 1\. Depend
Add this to you package's `pubspec.yaml` file:
```yaml
dependencies:
flutter_cupertino_date_picker: ^1.0.26+2
```#### 2\. Install
Run command:
```bash
$ flutter packages get
```#### 3\. Import
Import in Dart code:
```dart
import 'package:flutter_cupertino_date_picker/flutter_cupertino_date_picker.dart';
```#### 4\. Display DatePicker
##### Bottom Sheet DatePicker
```dart
/// Display date picker in bottom sheet.
///
/// context: [BuildContext]
/// minDateTime: [DateTime] minimum date time
/// maxDateTime: [DateTime] maximum date time
/// initialDateTime: [DateTime] initial date time for selected
/// dateFormat: [String] date format pattern
/// locale: [DateTimePickerLocale] internationalization
/// pickerMode: [DateTimePickerMode] display mode: date(DatePicker)、time(TimePicker)、datetime(DateTimePicker)
/// pickerTheme: [DateTimePickerTheme] the theme of date time picker
/// onCancel: [DateVoidCallback] pressed title cancel widget event
/// onClose: [DateVoidCallback] date picker closed event
/// onChange: [DateValueCallback] selected date time changed event
/// onConfirm: [DateValueCallback] pressed title confirm widget event
DatePicker.showDatePicker(
BuildContext context,
DateTime minDateTime,
DateTime maxDateTime,
DateTime initialDateTime,
String dateFormat,
DateTimePickerLocale locale: DATETIME_PICKER_LOCALE_DEFAULT,
DateTimePickerMode pickerMode: DateTimePickerMode.date,
DateTimePickerTheme pickerTheme: DatePickerTheme.Default,
DateVoidCallback onCancel,
DateVoidCallback onClose,
DateValueCallback onChange,
DateValueCallback onConfirm,
});
```##### DatePicker Widget
```dart
/// Display date picker widget.
///
/// minDateTime: [DateTime] minimum date time
/// maxDateTime: [DateTime] maximum date time
/// initialDateTime: [DateTime] initial date time for selected
/// dateFormat: [String] date format pattern
/// locale: [DateTimePickerLocale] internationalization
/// pickerTheme: [DateTimePickerTheme] the theme of date time picker
/// onCancel: [DateVoidCallback] pressed title cancel widget event
/// onChange: [DateValueCallback] selected date time changed event
/// onConfirm: [DateValueCallback] pressed title confirm widget event
DatePickerWidget({
DateTime minDateTime,
DateTime maxDateTime,
DateTime initialDateTime,
String dateFormat: DATETIME_PICKER_DATE_FORMAT,
DateTimePickerLocale locale: DATETIME_PICKER_LOCALE_DEFAULT,
DateTimePickerTheme pickerTheme: DatePickerTheme.Default,
DateVoidCallback onCancel,
DateValueCallback onChange,
DateValueCallback onConfirm,
})
```##### TimePicker Widget
```dart
/// Display time picker widget.
///
/// minDateTime: [DateTime] minimum date time
/// maxDateTime: [DateTime] maximum date time
/// initialDateTime: [DateTime] initial date time for selected
/// dateFormat: [String] date format pattern
/// locale: [DateTimePickerLocale] internationalization
/// pickerTheme: [DateTimePickerTheme] the theme of date time picker
/// minuteDivider: [int] minute restriction, e.g. 5: every 5th minute will be shown (0, 5, 10, 15 ...)
/// onCancel: [DateVoidCallback] pressed title cancel widget event
/// onChange: [DateValueCallback] selected date time changed event
/// onConfirm: [DateValueCallback] pressed title confirm widget event
TimePickerWidget({
DateTime minDateTime,
DateTime maxDateTime,
DateTime initialDateTime,
String dateFormat: DATETIME_PICKER_DATE_FORMAT,
DateTimePickerLocale locale: DATETIME_PICKER_LOCALE_DEFAULT,
DateTimePickerTheme pickerTheme: DatePickerTheme.Default,
int minuteDivider: 1,
DateVoidCallback onCancel,
DateValueCallback onChange,
DateValueCallback onConfirm,
})
```##### DateTimePicker Widget
```dart
/// Display date time picker widget.
///
/// minDateTime: [DateTime] minimum date time
/// maxDateTime: [DateTime] maximum date time
/// initialDateTime: [DateTime] initial date time for selected
/// dateFormat: [String] date format pattern
/// locale: [DateTimePickerLocale] internationalization
/// pickerTheme: [DateTimePickerTheme] the theme of date time picker
/// onCancel: [DateVoidCallback] pressed title cancel widget event
/// onChange: [DateValueCallback] selected date time changed event
/// onConfirm: [DateValueCallback] pressed title confirm widget event
DateTimePickerWidget({
DateTime minDateTime,
DateTime maxDateTime,
DateTime initialDateTime,
String dateFormat: DATETIME_PICKER_DATE_FORMAT,
DateTimePickerLocale locale: DATETIME_PICKER_LOCALE_DEFAULT,
DateTimePickerTheme pickerTheme: DatePickerTheme.Default,
DateVoidCallback onCancel,
DateValueCallback onChange,
DateValueCallback onConfirm,
})
```#### 5\. DateTimePickerLocale
Support:
- en_us: English (EN) United States ***[Default locale]***
- ar: Arabic (ar)
- ar_eg: Arabic (ar) Egypt
- bn: Bengali (BN)
- bs: Bosnian (BS)
- de: German (DE)
- es: Spanish (ES)
- fr: French (FR)
- hr: Croatian (HR)
- hu: Hungarian (HU)
- in_id: Bahasa (IN) Indonesia
- it: Italian (IT)
- jp: Japanese (JP)
- ko: Korea (KO)
- nl: Dutch (NL)
- pt_br: Portuguese (PT) Brazil
- ro: Romanian (RO)
- ru: Russian (RU)
- sr_cyrl: Serbia (sr) Cyrillic
- sr_latn: Serbia (sr) Latin
- tr: Turkish (TR)
- uk: Ukraine (UK)
- vi: Vietnamese (VI) Vietnam
- zh_cn: Chinese (ZH) Simplified##### Add more language
###### 1. Add language i18n file
Fork this project, add language file in `lib/src/i18n/` directory, e.g. `strings_en_us.dart`.
```dart
/// English (EN) United States
class _StringsEnUs extends _StringsI18n {
const _StringsEnUs();@override
String getCancelText() {
// TODO return cancel widget's text
return null;
}@override
String getDoneText() {
// TODO return done widget's text
return null;
}@override
List getMonths() {
// TODO return the array of month's full name [January, February ... December]
return null;
}@override
List getMonthsShort() {
// TODO return the array of month's short name [Jan, Feb ... Dec]. If return null, will substring the full name (max length is 3)
return null;
}@override
List getWeeksFull() {
// TODO return the array of week's full name [Monday, Tuesday ... Sunday]
return null;
}@override
List getWeeksShort() {
// TODO return the array of week's short name [Mon, Tue ... Sun]
return null;
}
}
```###### 2. Add Locale
Add language locale in `lib/src/i18n/date_picker_i18n.dart` file.
```dart
enum DateTimePickerLocale {
/// English (EN) United States
en_us,
}
```###### 3. Add Locale-Language relationship
Add language-locale relationship in `lib/src/i18n/date_picker_i18n.dart` file.
```dart
const Map datePickerI18n = {
DateTimePickerLocale.en_us: const _StringsEnUs(),
};
```#### 6\. dateFormat
|Pattern|Meaning |e.g. |
|:----|:------------------------|:---------|
|yyyy |year |2019, 2020|
|yy |year, 2 digits |19, 20|
|MMMM |month |January(en_us), 01(zh_cn)|
|MMM |month, abbreviated |Jan(en_us), 01(zh_cn)|
|MM |month, 2 digits |01、11
|M |month |1, 11|
|dd |day in month, 2 digits |05, 25|
|d |day in month |5, 25|
|EEEE |day of week |Monday(en_us), 星期一(zh_cn)|
|EEE |day of week, abbreviated |Mon(en_us), 周一(zh_cn)|
|HH |hour (0~23), 2 digits |04, 12, 20|
|H |hour (0~23) |4, 12, 20|
|mm |minute, 2 digits |05, 40|
|m |minute |5, 40|
|ss |second, 2 digits |06, 55|
|s |second |6, 55|
|yyyy年|format |2019年, 2020年|
|H时 |format |5时, 21时|##### Date Format Separator
Support separator: `|,-/\._: `.
#### 7\. DateTimePickerTheme
```dart
/// DateTimePicker theme.
///
/// [backgroundColor] DatePicker's background color.
/// [cancelTextStyle] Default cancel widget's [TextStyle].
/// [confirmTextStyle] Default confirm widget's [TextStyle].
/// [cancel] Custom cancel widget.
/// [confirm] Custom confirm widget.
/// [title] Custom title widget. If specify a title widget, the cancel and confirm widgets will not display. Must set [titleHeight] value for custom title widget.
/// [showTitle] Whether display title widget or not. If set false, the default cancel and confirm widgets will not display, but the custom title widget will display if had specified one custom title widget.
/// [pickerHeight] The value of DatePicker's height.
/// [titleHeight] The value of DatePicker's title height.
/// [itemHeight] The value of DatePicker's column height.
/// [itemTextStyle] The value of DatePicker's column [TextStyle].
const DateTimePickerTheme({
this.backgroundColor: DATETIME_PICKER_BACKGROUND_COLOR,
this.cancelTextStyle,
this.confirmTextStyle,
this.cancel,
this.confirm,
this.title,
this.showTitle: DATETIME_PICKER_SHOW_TITLE_DEFAULT,
this.pickerHeight: DATETIME_PICKER_HEIGHT,
this.titleHeight: DATETIME_PICKER_TITLE_HEIGHT,
this.itemHeight: DATETIME_PICKER_ITEM_HEIGHT,
this.itemTextStyle: DATETIME_PICKER_ITEM_TEXT_STYLE,
});
```## Example
[Example sources](https://github.com/wuzhendev/flutter-cupertino-date-picker/tree/master/example)
[Example APK](https://raw.githubusercontent.com/wuzhendev/assets/master/flutter-datepicker/flutter_cupertino_date_picker_v1.0.8.apk)

### DatePicker
![Example: DatePicker][1]
![Example: DatePickerWidget][2]
### TimePicker
![Example: TimePicker][3]
![Example: TimePickerWidget][4]
### DateTimePicker
![Example: DateTimePicker][5]
![Example: DateTimePickerWidget][6]
## License
```
Copyright 2018 wuzhenLicensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License athttp://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
```[1]:https://github.com/wuzhendev/assets/blob/master/flutter-datepicker/flutter_date_picker_14.jpg?raw=true
[2]:https://github.com/wuzhendev/assets/blob/master/flutter-datepicker/flutter_date_picker_15.jpg?raw=true
[3]:https://github.com/wuzhendev/assets/blob/master/flutter-datepicker/flutter_date_picker_16.jpg?raw=true
[4]:https://github.com/wuzhendev/assets/blob/master/flutter-datepicker/flutter_date_picker_17.jpg?raw=true
[5]:https://github.com/wuzhendev/assets/blob/master/flutter-datepicker/flutter_date_picker_18.jpg?raw=true
[6]:https://github.com/wuzhendev/assets/blob/master/flutter-datepicker/flutter_date_picker_19.jpg?raw=true