flutter_flexible_calendar
Highly video, feature-packed flutter_flexible_calendar widget for Flutter.
Standard |
Horizontal |
Single selected |
Multiple select |
Features
- Standar calendar user interface
- Hotizontal calendar user interface
- Calendar header change month and year.
- New Feature: Support the multiple select the same month.
- New Feature: Support range select with default start select and end select the same month.
- New Feature: Support set default single select date.
Usage
Make sure to check out examples
Installation
Add the following line to pubspec.yaml
:
dependencies:
flutter_flexible_calendar: ^1.0.1
Basic setup
The complete example is available here.
βStandard Calendar
FlutterFlexibleCalendarView(
showHeader: true,
headerBgColor: Colors.white38,
calendarType: FlutterFlexibleCalendarType.standard,
showWeekendDay: false,
disabledPreDay: true,
colorBg: Colors.transparent,
maxLimitYear: 2,
minLimitYear: 2,
month: DateTime(_currentMonth.year, _currentMonth.month, 1),
didResult: (item, datetime) {
print("itme: ${item?.date}");
print("itme: ${item?.dateTime}");
print("itme: ${item?.nameOffWeek}");
print("date: ${datetime?.day}");
print("date: ${datetime?.month}");
print("date: ${datetime?.year}");
},
didDisableItemClick: () {},
didWeekendItemClick: () {},
)
βHorizontal Calendar
FlutterFlexibleCalendarView(
showHeader: true,
headerBgColor: Colors.white38,
calendarType: FlutterFlexibleCalendarType.horizontal,
showWeekendDay: false,
disabledPreDay: true,
colorBg: Colors.transparent,
maxLimitYear: 2,
minLimitYear: 2,
month: DateTime(_currentMonth.year, _currentMonth.month, 1),
didResult: (item, datetime) {
print("itme: ${item?.date}");
print("itme: ${item?.dateTime}");
print("itme: ${item?.nameOffWeek}");
print("date: ${datetime?.day}");
print("date: ${datetime?.month}");
print("date: ${datetime?.year}");
},
didDisableItemClick: () {},
didWeekendItemClick: () {},
)
βSingle Select
FlutterFlexibleCalendarView(
showHeader: true,
headerBgColor: Colors.white38,
calendarType: FlutterFlexibleCalendarType.standard,
showWeekendDay: false,
disabledPreDay: true,
colorBg: Colors.transparent,
maxLimitYear: 2,
minLimitYear: 2,
month: DateTime(_currentMonth.year, _currentMonth.month, 1),
isMultipleSelected: false,
currentSelected: DateTime(2024, 4, 24),
didResult: (item, datetime) {
if (kDebugMode) {
print(
"date selected: ${item?.date}, ${item?.dateTime}, ${item?.nameOffWeek}");
}
},
didDisableItemClick: () {},
didWeekendItemClick: () {},
)
βMultiple Select
FlutterFlexibleCalendarView(
showHeader: true,
headerBgColor: Colors.white38,
calendarType: FlutterFlexibleCalendarType.standard,
showWeekendDay: false,
disabledPreDay: true,
colorBg: Colors.transparent,
maxLimitYear: 2,
minLimitYear: 2,
month: DateTime(_currentMonth.year, _currentMonth.month, 1),
isMultipleSelected: true,
setStartSelected: DateTime(2024, 4, 13),
setEndSelected: DateTime(2024, 4, 19),
didResult: (item, datetime) {
if (kDebugMode) {
print(
"date selected: ${item?.date}, ${item?.dateTime}, ${item?.nameOffWeek}");
}
},
didMultipleSelected: (firstDate, lastDate) {
if (kDebugMode) {
print(
"firstDate: ${firstDate?.date}, ${firstDate?.dateTime}, ${firstDate?.nameOffWeek}");
print(
"lastDate: ${lastDate?.date}, ${lastDate?.dateTime}, ${lastDate?.nameOffWeek}");
}
},
didDisableItemClick: () {},
didWeekendItemClick: () {},
)
Parameter
* showHeader : show calendar header.
* headerBgColor : set header background color.
* calendarType : set calendar type (horizontal, standard)
* showWeekendDay: show weekend day of previous of the month.
* disabledPreDay: disabled previous day.
* colorBg: set calendar background color.
* maxLimitYear: set max year allow move next.
* minLimitYear: set min year allow move back.
* month: set default month of calendar.
* didResult: function to return date selected.
* didDisableItemClick: function to return status when click on disabled item.
* didWeekendItemClick: function to return status when click on weekend of day.
* headerArrowLeft: allow change arrow left header icon.
* headerArrowRight: allow change arrow right header icon.
* isMultipleSelected : allow set multiple select (true , false)
* setStartSelected: set default start date select(Ex: DateTime(2024, 4, 13))
* setEndSelected: set default end date select(Ex: DateTime(2024, 4, 19))
* currentSelected: set default single date select(Ex: DateTime(2024, 4, 24))
* other you can check our class.
Events
use didResult
to return date user selected.
didResult: (item, datetime) {
}
use didDisableItemClick
to return status user click on disabled item date.
didDisableItemClick: () {
}
use didWeekendItemClick
to return status user click on item date weekend of previous of the month.
didWeekendItemClick: () {
}
use didMultipleSelected
to return first date select and last date select.
didMultipleSelected: (firstDate, lastDate) {
}
Hello everyone π
If you want to support me, feel free to do so.
Thanks
============================================
αα½ααααΈ α’αααααΆααα’ααααααΆπ
ααΎβα’αααβα ααβααΆααααβαααα»α ααΌαβααααΎβαααβααααΈ ,
ααΌαα’ααα»α
Libraries
- flutter_flexible_calendar
- Support for doing something awesome.