MhLabs.Calendar
2.0.0
dotnet add package MhLabs.Calendar --version 2.0.0
NuGet\Install-Package MhLabs.Calendar -Version 2.0.0
<PackageReference Include="MhLabs.Calendar" Version="2.0.0" />
paket add MhLabs.Calendar --version 2.0.0
#r "nuget: MhLabs.Calendar, 2.0.0"
// Install MhLabs.Calendar as a Cake Addin #addin nuget:?package=MhLabs.Calendar&version=2.0.0 // Install MhLabs.Calendar as a Cake Tool #tool nuget:?package=MhLabs.Calendar&version=2.0.0
MhLabs.Calendar
Common use cases
Current time with specified time zone
If you write code in one time zone and run it in another, this is often not as trivial as it sounds.
This will get the current time in specified time zone wherever code is run:
var now = Calendar.Now(TimeZones.Sweden);
Parse value without any interpretation of time zone info
E.g. if you have a DateTime value for the local time where your users are but run the code in Ireland you want to make sure the DateTime value is not assumed to be UTC. (Of course, if the value includes offset info, use DateTimeOffset.Parse instead.)
var date = Calendar.ParseAsLiteral("2020-03-31");
Format DateTime in round-trip format
Use Calendar.ToRoundTripDate
or Calendar.ToRoundTripDateTime
to convert DateTime to a round-trip string suitable for databases, API responses etc. The correct offset value will be added for the time zone you specify.
Method reference
Current Time
Specify one of the constants in TimeZones to get the current time.
E.g.
var now = Calendar.Now(TimeZones.Sweden);
Parse date string without conversions
This is useful if you just want a date without considering time or conversions.
This means if you send in "2020-03-31" you will always get a DateTime with Kind set to unspecified and the value being 2020-03-31, regardless of which time zone the code runs in.
Expected format is "YYYY-MM-DD", "YYYY-MM-DDThh:mm:ss", "YYYY-MM-DD hh:mm:ss" or YYYY-MM-DD hh:mm. Any offset info or other info afterwards is ignored.
E.g.
var date = Calendar.ParseAsLiteral("2020-03-31");
var dateTime = Calendar.ParseAsLiteral("2020-03-31 01:20:55");
Convert offset value to another time zone
E.g. if you have an offset value in UTC and want to convert it to Swedish time.
var swedishTime = Calendar.ConvertFromOffset("2020-03-24T23:00:00+00:00", TimeZones.Sweden);
// -> 2020-03-25 00:00:00
Get week number for date
According to ISO/Scandinavian standard with first 4-day week.
var week = Calendar.GetWeekOfYear("2019-12-30");
// -> 1, note that .NET Framework Calendar will return 53 regardless of parameters which is incorrect
Format as round-trip with or without time
Useful for storing in databases, sending to API clients etc.
Note that no conversion is made regarding any included offset, the DateTime value is treated as a literal value and the formatting only means that the correct offset suffix is added, not that date or time is changed.
Date only
var date = new DateTime(2020, 03, 12, 5, 45, 36);
var clientFormat = Calendar.ToRoundTripDate(date, TimeZones.Sweden);
// -> 2020-03-12T00:00:00+01:00
Date and time
var dateTime = new DateTime(2020, 03, 12, 5, 45, 36);
var clientFormat = Calendar.ToRoundTripDateTime(dateTime, TimeZones.Sweden);
// -> 2020-03-12T05:45:36+01:00
Convert to universal time
Useful when you have a swedish datetime in the format of yyyy-MM-dd HH:mm:ss and want to convert it to UTC
var dateTime = "2020-06-30 15:35:00";
var clientFormat = Calendar.ConvertToUniversalTime(dateTime, TimeZones.Sweden);
// -> 2020-03-12 13:35:00
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.1 is compatible. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.1
- TimeZoneConverter (>= 6.0.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.