/Embedded.Json.Localization

.NET Core localization using embedded JSON resources

Primary LanguageC#MIT LicenseMIT

Embedded.Json.Localization

Description

This project allows you to use JSON files for .NET Core Localization instead of resx files.

Features

  1. Works with multiple projects/assemblies (i.e. the resources can stay in the project where they belong).
  2. Automatic fallback to parent culture (e.g. if a resource is not found in 'de-CH', it is also searched for in 'de' resources).

Configuration

The following are the required steps to activate the embedded JSON localization. For all other information consider the official Globalization and localization in ASP.NET Core docs.

  1. Add the package reference:

NuGet

  1. In Startup.cs:
public void ConfigureServices(...) 
{
    ...
    services.AddJsonLocalization();
    ...
}
  1. Embed the json in the corresponding project files (csproj). For example:
  <ItemGroup>
    <EmbeddedResource Include="**/*.de-CH.json" />
  </ItemGroup>

Example

You can find a fully working sample in the source code. Note that the cookie consent has been localized (to show an instance of view localization) and the header messages of the About and Contact screens (to have an example of localization happening in a controller inlcuding fallback to parent culture).