Flutter Week View
Displays a highly customizable week view (or day view) which is able to display events, to be scrolled, to be zoomed-in & out and a lot more !
Flutter Week View is highly inspired by Android Week View.
Getting Started
Getting started with Flutter Week View is very straight forward.
You have the choice between two widgets : DayView and WeekView.
Use the first one to display a single day and use the second one to display
multiple days.
Example
If you want a real project
example, you can check this one on Github.
Day View
Snippet :
// Let's get two dates :
DateTime now = DateTime.now();
DateTime date = DateTime(now.year, now.month, now.day);
// And here's our widget !
return DayView(
date: now,
events: [
FlutterWeekViewEvent(
title: 'An event 1',
description: 'A description 1',
start: date.subtract(Duration(hours: 1)),
end: date.add(Duration(hours: 18, minutes: 30)),
),
FlutterWeekViewEvent(
title: 'An event 2',
description: 'A description 2',
start: date.add(Duration(hours: 19)),
end: date.add(Duration(hours: 22)),
),
FlutterWeekViewEvent(
title: 'An event 3',
description: 'A description 3',
start: date.add(Duration(hours: 23, minutes: 30)),
end: date.add(Duration(hours: 25, minutes: 30)),
),
FlutterWeekViewEvent(
title: 'An event 4',
description: 'A description 4',
start: date.add(Duration(hours: 20)),
end: date.add(Duration(hours: 21)),
),
FlutterWeekViewEvent(
title: 'An event 5',
description: 'A description 5',
start: date.add(Duration(hours: 20)),
end: date.add(Duration(hours: 21)),
),
],
style: const DayViewStyle.fromDate(
date: now,
currentTimeCircleColor: Colors.pink,
),
);
Result :
Week view
Snippet :
// Let's get two dates :
DateTime now = DateTime.now();
DateTime date = DateTime(now.year, now.month, now.day);
// And here's our widget !
return WeekView(
dates: [date.subtract(Duration(days: 1)), date, date.add(Duration(days: 1))],
events: [
FlutterWeekViewEvent(
title: 'An event 1',
description: 'A description 1',
start: date.subtract(Duration(hours: 1)),
end: date.add(Duration(hours: 18, minutes: 30)),
),
FlutterWeekViewEvent(
title: 'An event 2',
description: 'A description 2',
start: date.add(Duration(hours: 19)),
end: date.add(Duration(hours: 22)),
),
FlutterWeekViewEvent(
title: 'An event 3',
description: 'A description 3',
start: date.add(Duration(hours: 23, minutes: 30)),
end: date.add(Duration(hours: 25, minutes: 30)),
),
FlutterWeekViewEvent(
title: 'An event 4',
description: 'A description 4',
start: date.add(Duration(hours: 20)),
end: date.add(Duration(hours: 21)),
),
FlutterWeekViewEvent(
title: 'An event 5',
description: 'A description 5',
start: date.add(Duration(hours: 20)),
end: date.add(Duration(hours: 21)),
),
],
);
Result :
Options
Common options
Here are the options that are available for both DayView and WeekView :
eventsEvents to display.styleAllows you to style your widget. A lot of different styles are available so don't hesitate to try them out !hourColumnStyleSame, it allows you to style the hour column on the left.controllerControllers allow you to manually change the zoom settings.inScrollableWidgetWhether to put the widget in a scrollable widget (disable if you want to manage the scroll by yourself).minimumTimeThe minimum hour and minute to display in a day.maximumTimeThe maximum hour and minute to display in a day.initialTimeThe initial hour and minute to put the widget on.userZoomableWhether the user is able to (un)zoom the widget.currentTimeIndicatorBuilderAllows you to change the default current time indicator (rule and circle).onHourColumnTappedDownProvides a tapped down callback for the hour column. Pretty useful if you want your users to add your own events at a specific time.onBackgroundTappedDownProvides a similar callback as the above, but when the user clicks on the background (an empty region of the calendar).onDayBarTappedDownProvides a tapped down callback for the day bar.dragAndDropOptionsEnables drag-and-drop of events.resizeEventOptionsEnables resizing events, by dragging the bottom of the event up/down.eventWidgetBuilderThe widget builder that customizes how events are rendered.
Flutter day view
Here are the specific options of DayView :
dateThe widget date.dayBarStyleThe day bar style.
Flutter week view
Here are the specific options of WeekView :
datesThe widget dates.dayViewStyleBuilderThe function that allows to build a Day View style according to the provided date.dayBarStyleBuilderThe function that allows to build a Day Bar style according to the provided date.
Please note that you can create a WeekView instance using a builder.
All previous options are still available but you don't need to provide the dates list.
However, you need to provide a DateCreator (and a date count if you can, if it's impossible for you to do it then scrollToCurrentTime will not scroll to the current date).
Contributions
You have a lot of options to contribute to this project ! You can :
Libraries
- flutter_week_view
- Flutter Week View, created by Skyost Github : https://github.com/Skyost/FlutterWeekView