dotnet-timezone▌
github/awesome-copilot · updated Apr 8, 2026
Resolve timezone questions for .NET and C# code with production-safe guidance and copy-paste-ready snippets.
.NET Timezone
Resolve timezone questions for .NET and C# code with production-safe guidance and copy-paste-ready snippets.
Start With The Right Path
Identify the request type first:
- Address or location lookup
- Timezone ID lookup
- UTC/local conversion
- Cross-platform timezone compatibility
- Scheduling or DST handling
- API or persistence design
If the library is unclear, default to TimeZoneConverter for cross-platform work. If the scenario involves recurring schedules or strict DST rules, prefer NodaTime.
Resolve Addresses And Locations
If the user provides an address, city, region, country, or document containing place names:
- Extract each location from the input.
- Read
references/timezone-index.mdfor common Windows and IANA mappings. - If the exact location is not listed, infer the correct IANA zone from geography, then map it to the Windows ID.
- Return both IDs and a ready-to-use C# example.
For each resolved location, provide:
Location: <resolved place>
Windows ID: <windows id>
IANA ID: <iana id>
UTC offset: <standard offset and DST offset when relevant>
DST: <yes/no>
Then include a cross-platform snippet like:
using TimeZoneConverter;
TimeZoneInfo tz = TZConvert.GetTimeZoneInfo("Asia/Colombo");
DateTime local = TimeZoneInfo.ConvertTimeFromUtc(DateTime.UtcNow, tz);
If multiple locations are present, include one block per location and then a combined multi-timezone snippet.
If a location is ambiguous, list the possible timezone matches and ask the user to choose the correct one.
Look Up Timezone IDs
Use references/timezone-index.md for Windows to IANA mappings.
Always provide both formats:
- Windows ID for
TimeZoneInfo.FindSystemTimeZoneById()on Windows - IANA ID for Linux, containers,
NodaTime, andTimeZoneConverter
Generate Code
Use references/code-patterns.md and pick the smallest pattern that fits:
- Pattern 1:
TimeZoneInfofor Windows-only code - Pattern 2:
TimeZoneConverterfor cross-platform conversion - Pattern 3:
NodaTimefor strict timezone arithmetic and DST-sensitive scheduling - Pattern 4:
DateTimeOffsetfor APIs and data transfer - Pattern 5: ASP.NET Core persistence and presentation
- Pattern 6: recurring jobs and schedulers
- Pattern 7: ambiguous and invalid DST timestamps
Always include package guidance when recommending third-party libraries.
Warn About Common Pitfalls
Mention the relevant warning when applicable:
TimeZoneInfo.FindSystemTimeZoneById()is platform-specific for timezone IDs.- Avoid storing
DateTime.Nowin databases; store UTC instead. - Treat
DateTimeKind.Unspecifiedas a bug risk unless it is deliberate input. - DST transitions can skip or repeat local times.
- Azure Windows and Azure Linux environments may expect different timezone ID formats.
Response Shape
For address and location requests:
- Return the resolved timezone block for each location.
- State the recommended implementation in one sentence.
- Include a copy-paste-ready C# snippet.
For code and architecture requests:
- State the recommended approach in one sentence.
- Provide the timezone IDs if relevant.
- Include the minimal working code snippet.
- Mention the package requirement if needed.
- Add one pitfall warning if it matters.
Keep responses concise and code-first.
References
references/timezone-index.md: common Windows and IANA timezone mappingsreferences/code-patterns.md: ready-to-use .NET timezone patterns
Discussion
Product Hunt–style comments (not star reviews)- No comments yet — start the thread.
Ratings
4.7★★★★★74 reviews- ★★★★★Soo Diallo· Dec 28, 2024
Keeps context tight: dotnet-timezone is the kind of skill you can hand to a new teammate without a long onboarding doc.
- ★★★★★Carlos Harris· Dec 24, 2024
dotnet-timezone reduced setup friction for our internal harness; good balance of opinion and flexibility.
- ★★★★★Sofia Agarwal· Dec 24, 2024
We added dotnet-timezone from the explainx registry; install was straightforward and the SKILL.md answered most questions upfront.
- ★★★★★Soo Menon· Dec 12, 2024
dotnet-timezone reduced setup friction for our internal harness; good balance of opinion and flexibility.
- ★★★★★Arya Gonzalez· Dec 8, 2024
I recommend dotnet-timezone for anyone iterating fast on agent tooling; clear intent and a small, reviewable surface area.
- ★★★★★Valentina Flores· Dec 8, 2024
Keeps context tight: dotnet-timezone is the kind of skill you can hand to a new teammate without a long onboarding doc.
- ★★★★★Sofia Bansal· Dec 4, 2024
dotnet-timezone is among the better-maintained entries we tried; worth keeping pinned for repeat workflows.
- ★★★★★Ava Huang· Nov 27, 2024
Useful defaults in dotnet-timezone — fewer surprises than typical one-off scripts, and it plays nicely with `npx skills` flows.
- ★★★★★Camila Torres· Nov 27, 2024
Registry listing for dotnet-timezone matched our evaluation — installs cleanly and behaves as described in the markdown.
- ★★★★★Soo Abebe· Nov 23, 2024
dotnet-timezone fits our agent workflows well — practical, well scoped, and easy to wire into existing repos.
showing 1-10 of 74