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