renderDateOrDayOfWeek method
This function renderDateOrDayOfWeek renders the week view or the month view. It is responsible for displaying a calendar tile. This can be a day (i.e. "Mon", "Tue" ...) in the header row or a date tile for each day of a week or a month. The property isDayOfWeek of the NeatCleanCalendarTile decides, if the rendered item should be a day or a date tile.
Implementation
Widget renderDateOrDayOfWeek(BuildContext context) {
// We decide, if this calendar tile should display a day name in the header row. If this is the
// case, we return a widget, that contains a text widget with style property [dayOfWeekStyle]
if (isDayOfWeek) {
return new GestureDetector(
child: new Container(
alignment: Alignment.center,
child: Text(
dayOfWeek ?? '',
style: dayOfWeekStyle,
),
),
);
} else {
// Here the date tiles get rendered. Initially eventCount is set to 0.
// Every date tile can show up to three dots representing an event.
int eventCount = 0;
return GestureDetector(
onTap: onDateSelected, // react on tapping
child: Padding(
padding: const EdgeInsets.all(1.0),
child: Container(
// If this tile is the selected date, draw a colored circle on it. The circle is filled with
// the color passed with the selectedColor parameter or red color.
decoration: isSelected && date != null
? BoxDecoration(
shape: BoxShape.circle,
color: selectedColor != null
? Utils.isSameDay(this.date!, DateTime.now())
? selectedTodayColor != null
? selectedTodayColor
: Colors.red
: selectedColor
: Theme.of(context).primaryColor,
image: events != null && events!.isNotEmpty
? icon != '' && icon != null
? DecorationImage(
fit: BoxFit.cover,
image: providerImage(icon!),
)
: null
: null,
)
: events == null
? BoxDecoration()
: events!.isNotEmpty
? BoxDecoration(
shape: BoxShape.circle,
image: icon != '' && icon != null
? DecorationImage(
fit: BoxFit.cover,
image: providerImage(icon!),
)
: null,
)
: BoxDecoration(), // no decoration when not selected
alignment: Alignment.center,
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
// Date display
Text(
date != null ? DateFormat("d").format(date!) : '',
style: TextStyle(
fontSize: 14.0,
fontWeight: FontWeight.w400,
color: isSelected && this.date != null
? Colors.white
: Utils.isSameDay(this.date!, DateTime.now())
? todayColor
: inMonth
? defaultDayColor != null
? defaultDayColor
: events != null &&
events!.isNotEmpty &&
icon != ''
? Colors.white
: Colors.black
: (defaultOutOfMonthDayColor != null
? defaultOutOfMonthDayColor
: Colors.grey),
),
textScaler: TextScaler.noScaling,
// Grey color for previous or next months dates
),
// Dots for the events
events != null && events!.length > 0
? Row(
mainAxisAlignment: MainAxisAlignment.center,
children: events!.map((event) {
eventCount++;
// Show a maximum of 3 dots.
if (eventCount > 3) return Container();
return Container(
margin: EdgeInsets.only(
left: 2.0, right: 2.0, top: 1.0),
width: 5.0,
height: 5.0,
decoration: BoxDecoration(
shape: BoxShape.circle,
// If event is done (isDone == true) set the color of the dots to
// the eventDoneColor (if given) otherwise use the primary color of
// the theme
// If the event is not done yet, we use the given eventColor or the
// color property of the NeatCleanCalendarEvent. If both aren't set, then
// the accent color of the theme get used.
color: (() {
if (isSelected) return Colors.white;
// If eventColor property was not set, the color defined for the event
// gets used. If the eveent has its property isDone set to true, the
// eventDoneColor gets used.
if (event.isDone) {
return eventDoneColor ??
Theme.of(context).primaryColor;
}
return eventColor ??
event.color ??
Theme.of(context).colorScheme.secondary;
}()),
),
);
}).toList(),
)
: Container(),
],
),
),
),
);
}
}