Plugin.Maui.Calendar 2.0.10

dotnet add package Plugin.Maui.Calendar --version 2.0.10
                    
NuGet\Install-Package Plugin.Maui.Calendar -Version 2.0.10
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Plugin.Maui.Calendar" Version="2.0.10" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Plugin.Maui.Calendar" Version="2.0.10" />
                    
Directory.Packages.props
<PackageReference Include="Plugin.Maui.Calendar" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Plugin.Maui.Calendar --version 2.0.10
                    
#r "nuget: Plugin.Maui.Calendar, 2.0.10"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Plugin.Maui.Calendar@2.0.10
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Plugin.Maui.Calendar&version=2.0.10
                    
Install as a Cake Addin
#tool nuget:?package=Plugin.Maui.Calendar&version=2.0.10
                    
Install as a Cake Tool

Calendar Plugin for .NET MAUI

This is a .NET MAUI port of the lilcodelab Xamarin.Forms Calendar Plugin

Available on NuGet: https://www.nuget.org/packages/Plugin.Maui.Calendar NuGet

Simple cross-platform plugin for Calendar control featuring:

  • Displaying events by binding EventCollection
  • Localization support with System.Globalization.CultureInfo
  • Customizable colors, day view sizes/label styles, custom Header/Footer template support
  • UI reactive to EventCollection, Culture, and other changes

What's new

V2.0.0

  • Updated to .NET 9
  • Optimized startup time: iOS 20 % / Android 40 %
  • Fixed memory leaks*
  • Revamped calendar structure
  • Added Styles (check Available Styles section) that replace some properties
  • Added WeekendTitleStyle
  • Added sample page (Default calendar) to test memory leaks with MemoryToolkit.Maui )
  • Updated samples
  • Added native digits support (added UseNativeDigits Property)
  • Added OtherMonthWeekIsVisible and DayViewBorderMargin properties
  • Added AutoChangeMonthOnDayTap property — allows automatically switching the displayed month when user taps on a day from another month (disabled by default)
  • Added UseAbbreviatedDayNames property — allows using built-in .NET AbbreviatedDayNames without trimming. When this property is enabled, DaysTitleMaximumLength is ignored.

Breaking Changes

Properties that Styles have replaced

DayViewFontSize --> DaysLabelStyle
MonthLabelColor --> MonthLabelStyle
YearLabelColor --> YearLabelStyle

ArrowsBackgroundColor, ArrowsBorderColor, ArrowsBorderWidth, ArrowsFontAttribute, ArrowsFontSize, ArrowsFontFamily, ArrowsColor --> 
ArrowsSymbolPrev --> PreviousMonthArrowButtonStyle
ArrowsSymbolNext --> NextMonthArrowButtonStyle
ArrowsSymbolPrev --> PreviousYearArrowButtonStyle
ArrowsSymbolNext --> NextYearArrowButtonStyle

ArrowsFontFamily, ArrowsColor --> FooterArrowLabelStyle
SelectedDateColor --> SelectedDateLabelStyle

DaysTitleHeight, DaysTitleColor --> DaysTitleLabelStyle
DaysTitleHeight, DaysTitleWeekendColor --> WeekendTitleStyle

⚠️ Breaking Change:
The SelectedDates property is now an ObservableCollection<DateTime>.
To ensure the calendar updates when dates are added/removed, use:

SelectedDates = new ObservableCollection<DateTime> { ... };

Do not use List<DateTime> for SelectedDates binding.

V1.0.x

  • Removed all the platform-specific code, hence it supports all available .NET MAUI backends: iOS, Android, Windows, Mac, Tizen (not tested yet)
  • Added Multiselection support (Latest PR that was not merged previously)
  • Refactored and revamped code
  • Updated to .NET 8
  • Added OnShownDateChangedCommand so we can take action when a date is changed.
  • Added new property OtherMonthSelectedDayColor
  • Fixed bug with OtherMonthDayIsVisible property
  • Added a weekend calendar sample
  • Added a Windows 11 calendar sample
  • Added theme support
  • Added new property FirstDayOfWeek
  • Added support for multiple event dots (multidots) in calendar
  • Added MonthChanged Event and MonthChangedCommand
  • Added AllowDeselecting property
  • Added SelectedDatesRangeBackgroundColor property
  • Updated samples

YouTube

Free and Complete Calendar Control for .NET MAUI: Plugin.Maui.Calendar

Screenshots

Android iOS
Android Calendar Screenshot iPhone Calendar Screenshot
Win Mac
Windiws Calendar Screenshot Mac Calendar Screenshot

Theme support | Ligth | Dark | Settings | | ------- | ------ | ------ | | Light theme Screenshot | Dark theme Screenshot | Settings Page Screenshot |

Culture support | Android | iOS | | ------- | ------ | | Android Culture Screenshot | iPhone Culture Screenshot |

New Samples

Windows 11 calendar | Win | Mac | | ------- | ------ | | Windiws 11 android Calendar Screenshot | Windiws 11 Calendar IOS Screenshot |

Weekend calendar | Android | IOS | | ------- | ------ | | Weekend calendar Android Screenshot | Weekend calendar IOS Screenshot |

Usage

To get started just install the package via Nuget. You can take a look on the sample app to get started or continue reading.

Reference the following xmlns to your page:

xmlns:controls="clr-namespace:Plugin.Maui.Calendar.Controls;assembly=Plugin.Maui.Calendar" 

Basic control usage:

<controls:Calendar
        Day="14"
        Month="5"
        Year="2019"
        VerticalOptions="Fill"
        HorizontalOptions="Fill"/>

Bindable properties:

  • Culture CultureInfo calender culture/language
  • Day int currently viewing day
  • Month int currently viewing month
  • Year int currently viewing year
  • Events EventCollection (from package) your events for calender
  • Custom colors, fonts, sizes ...

Remark: You can use ShownDate as an alternative to Year, Month and Day

<controls:Calendar
        ShownDate="2019-05-14"
        VerticalOptions="Fill"
        HorizontalOptions="Fill"/>
Binding events:

In your XAML, add the data template for events, and bind the events collection, example:

<controls:Calendar
    Events="{Binding Events}">
    <controls:Calendar.EventTemplate>
        <DataTemplate>
            <StackLayout
                Padding="15,0,0,0">
                <Label
                    Text="{Binding Name}"
                    FontAttributes="Bold"
                    FontSize="Medium" />
                <Label
                    Text="{Binding Description}"
                    FontSize="Small"
                    LineBreakMode="WordWrap" />
            </StackLayout>
        </DataTemplate>
    </controls:Calendar.EventTemplate>
</controls:Calendar>

In your ViewModel reference the following namespace:

using Plugin.Maui.Calendar.Models;

Add property for Events:

public EventCollection Events { get; set; }

Initialize Events with your data:

 Events = new EventCollection
 {
    [DateTime.Now] = new List<EventModel>
    {
        new() { Name = "Cool event1", Description = "This is Cool event1's description!" },
        new() { Name = "Cool event2", Description = "This is Cool event2's description!" }
    },
    // 5 days from today
    [DateTime.Now.AddDays(5)] = new List<EventModel>
    {
        new() { Name = "Cool event3", Description = "This is Cool event3's description!" },
        new() { Name = "Cool event4", Description = "This is Cool event4's description!" }
    },
    // 3 days ago
    [DateTime.Now.AddDays(-3)] = new List<EventModel>
    {
        new() { Name = "Cool event5", Description = "This is Cool event5's description!" }
    },
    // custom date
    [new DateTime(2024, 3, 16)] = new List<EventModel>
    {
        new() { Name = "Cool event6", Description = "This is Cool event6's description!" }
    }
 };

Initialize Events with your data and a different dot color per day:

Events = new EventCollection
{
    //2 days ago
    [DateTime.Now.AddDays(-2)] = new DayEventCollection<EventModel>(Colors.Purple, Colors.Purple)
    {
        new() { Name = "Cool event1", Description = "This is Cool event1's description!" },
        new() { Name = "Cool event2", Description = "This is Cool event2's description!" }
    },
    // 5 days ago
    [DateTime.Now.AddDays(-5)] = new DayEventCollection<EventModel>(Colors.Blue, Colors.Blue)
    {
        new() { Name = "Cool event3", Description = "This is Cool event3's description!" },
        new() { Name = "Cool event4", Description = "This is Cool event4's description!" }
    },
};
//4 days ago
Events.Add(DateTime.Now.AddDays(-4), new DayEventCollection<EventModel>(GenerateEvents(10, "Cool")) { EventIndicatorColor = Colors.Green, EventIndicatorSelectedColor = Colors.Green });

Where EventModel is just an example, it can be replaced by any data model you desire.

EventsCollection is just a wrapper over Dictionary<DateTime, ICollection> exposing custom Add method and this[DateTime] indexer which internally extracts the .Date component of DateTime values and uses it as a key in this dictionary.

DayEventCollection is just a wrapper over List<T> exposing custom properties EventIndicatorColor and EventIndicatorSelectedColor for assigning a custom color to the dot.

DayTappedCommand

The DayTappedCommand is triggered when a user taps on a specific day in the calendar.

XAML Usage:

DayTappedCommand="{Binding DayTappedCommand}"
Set up culture

In your ViewModel add property for Culture:

public CultureInfo Culture => new CultureInfo("hr-HR")

In XAML add Culture binding

<controls:Calendar
    Culture="{Binding Culture}"/>
</controls:Calendar>
Available color customization

Sample properties:

EventIndicatorColor="Red"
EventIndicatorSelectedColor="White"
DeselectedDayTextColor="Blue"
OtherMonthDayColor="Gray"
SelectedDayTextColor="Cyan"
SelectedDayBackgroundColor="DarkCyan"
SelectedTodayTextColor="Green"
TodayOutlineColor="Blue"
TodayFillColor="Silver"
TodayTextColor="Yellow"
OtherMonthSelectedDayColor="HotPink"
Available Styles
Style Key Based On (DefaultStyles)
DaysLabelStyle DefaultStyles.DefaultLabelStyle
MonthLabelStyle DefaultStyles.DefaultMonthLabelStyle
YearLabelStyle DefaultStyles.DefaultYearLabelStyle
PreviousMonthArrowButtonStyle DefaultStyles.DefaultPreviousMonthArrowButtonStyle
NextMonthArrowButtonStyle DefaultStyles.DefaultNextMonthArrowButtonStyle
PreviousYearArrowButtonStyle DefaultStyles.DefaultPreviousYearArrowButtonStyle
NextYearArrowButtonStyle DefaultStyles.DefaultNextYearArrowButtonStyle
FooterArrowLabelStyle DefaultStyles.DefaultFooterArrowLabelStyle
SelectedDateLabelStyle DefaultStyles.DefaultSelectedDateLabelStyle
WeekdayTitleStyle DefaultStyles.DefaultDaysTitleLabelStyle
WeekendTitleStyle DefaultStyles.DefaultWeekendTitleStyle
Available customization properties
FirstDayOfWeek="Monday"
UseNativeDigits="True"
OtherMonthWeekIsVisible="False"
DayViewBorderMargin
AutoChangeMonthOnDayTap="True"
UseAbbreviatedDayNames="True"  
Calendar Layout customizations

You can set the layout of the calendar with the property CalendarLayout

  • Available layouts are:

    OneWeek - only one week is shown

    TwoWeeks - two weeks are shown

    Month - the whole month is shown (default value)

CalendarLayout="Month"

You can also choose to display the shown week number instead of the month name

CalendarLayout="Week"
WeekViewUnit="WeekNumber"
Event indicator customizations

You can customize how the event indication will look with the property EventIndicatorType

  • Available indicators are: BottomDot - event indicator as dot bellow of date in the calendar (default value) TopDot - event indicator as the dot on top of the date in the calendar Background - event indicator as colored background in calendar BackgroundFull // event indicator as larger size colored background in the calendar
EventIndicatorType="Background"
Calendar swipe customizations

You can write your own customizations commands for swipe.

SwipeLeftCommand="{Binding SwipeLeftCommand}"
SwipeRightCommand="{Binding SwipeRightCommand}"
SwipeUpCommand="{Binding SwipeUpCommand}"

You can also disable default swipe actions.

SwipeToChangeMonthEnabled="False"
SwipeUpToHideEnabled="False"
Selection type of calendar

You can either use the Calender class implementation for a single selection mode, multiselection mode or RangeSelectionCalendar for a range selection mode.

    <plugin:Calendar
        SelectedDate="{Binding SelectedDate}"/>

On the RangeSelectionCalendar you can use binding for start date SelectedStartDate and end date SelectedEndDate or get list of selected dates with SelectedDates.

    <plugin:RangeSelectionCalendar
        x:Name="rangedCalendar"
        SelectedDates="{Binding SelectedDates}"
        SelectedEndDate="{Binding SelectedEndDate}"
        SelectedStartDate="{Binding SelectedStartDate}">

On the MultiselectionCalendar you can select multiple separate dates

    <plugin:MultiSelectionCalendar
        Events="{Binding Events}"
        MaximumDate="{Binding MaximumDate}"
        MinimumDate="{Binding MinimumDate}"
        Month="{Binding Month}" >

Remark: Don't use both SelectedDates and SelectedStartDate/SelectedEndDate

Other customizations

Enable/Disable the visibility of the Events scrollview panel at the bottom Sample properties:

EventsScrollViewVisible="True"
Section templates

There are several templates that can be used to customize the calendar. You can find an example for each one in the AdvancedPage.xaml. You can create your own custom control file or you can also write customization directly inside of Templates.

Calendar control sections

These sections provide customization over appearance of the controls of the calendar, like showing the selected month and year, month selection controls etc.

HeaderSectionTemplate

Customize the header section (top of the calendar control). Example from AdvancedPage.xaml

<plugin:Calendar.HeaderSectionTemplate>
    <controls:CalendarHeader />
</plugin:Calendar.HeaderSectionTemplate>
FooterSectionTemplate

Customize the footer section (under the calendar part, above the events list). Example from AdvancedPage.xaml

<plugin:Calendar.FooterSectionTemplate>
    <DataTemplate>
        <controls:CalendarFooter />
    </DataTemplate>
</plugin:Calendar.FooterSectionTemplate>
BottomSectionTemplate

Customize the bottom section (at the bottom of the calendar control, below the events list). Example from AdvancedPage.xaml

<plugin:Calendar.BottomSectionTemplate>
    <controls:CalendarBottom />
</plugin:Calendar.BottomSectionTemplate>
Event templates

These templates provide customization for the events list.

EventTemplate

Customize the appearance of the events section. Example from AdvancedPage.xaml

<plugin:Calendar.EventTemplate>
    <DataTemplate>
        <controls:CalenderEvent CalenderEventCommand="{Binding BindingContext.EventSelectedCommand, Source={x:Reference advancedCalendarPage}}" />
    </DataTemplate>
</plugin:Calendar.EventTemplate>
EmptyTemplate

Customize what to show in case the selected date has no events. Example from AdvancedPage.xaml

<plugin:Calendar.EmptyTemplate>
    <DataTemplate>
        <StackLayout>
            <Label Text="NO EVENTS FOR THE SELECTED DATE" HorizontalTextAlignment="Center" Margin="0,5,0,5" />
        </StackLayout>
    </DataTemplate>
</plugin:Calendar.EmptyTemplate>
Product Compatible and additional computed target framework versions.
.NET net9.0 is compatible.  net9.0-android was computed.  net9.0-android35.0 is compatible.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-ios18.0 is compatible.  net9.0-maccatalyst was computed.  net9.0-maccatalyst18.0 is compatible.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net9.0-windows10.0.19041 is compatible.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
2.0.10 969 9/16/2025
2.0.9 1,153 8/22/2025
2.0.8 530 8/6/2025
2.0.7 3,251 6/25/2025
2.0.6 777 5/30/2025
2.0.5 1,212 5/8/2025
2.0.3 1,196 4/15/2025
2.0.2 323 4/14/2025
2.0.1 292 4/11/2025
2.0.0 688 4/4/2025
1.2.6 8,015 1/28/2025
1.2.5 3,560 1/14/2025
1.2.4 1,833 12/17/2024
1.2.3 2,818 11/25/2024
1.2.2 13,376 9/3/2024
1.2.1 12,727 8/6/2024
1.2.0 5,744 6/24/2024
1.1.9 876 6/19/2024
1.1.8 568 6/4/2024
1.1.7 3,335 5/17/2024
1.1.6 1,825 4/17/2024
1.1.5 294 4/16/2024
1.1.4 5,102 2/27/2024
1.1.3 240 2/26/2024
1.1.2 1,485 2/20/2024
1.1.1 1,669 1/5/2024
1.1.0 383 1/4/2024
1.0.11 233 1/3/2024
1.0.10 220 1/3/2024
1.0.9 230 1/2/2024
1.0.8 244 1/2/2024
1.0.7 257 12/28/2023
1.0.6 6,755 12/15/2023
1.0.5 676 11/27/2023
1.0.3 4,003 8/23/2023
1.0.2 273 8/22/2023
1.0.1 274 8/18/2023
1.0.0 459 8/17/2023

* Added UseAbbreviatedDayNames property
                       * Updated maui nugets to 9.0.100