LocalizationProvider 8.2.4

dotnet add package LocalizationProvider --version 8.2.4                
NuGet\Install-Package LocalizationProvider -Version 8.2.4                
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="LocalizationProvider" Version="8.2.4" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add LocalizationProvider --version 8.2.4                
#r "nuget: LocalizationProvider, 8.2.4"                
#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.
// Install LocalizationProvider as a Cake Addin
#addin nuget:?package=LocalizationProvider&version=8.2.4

// Install LocalizationProvider as a Cake Tool
#tool nuget:?package=LocalizationProvider&version=8.2.4                

Quality Gate Status

Supporting LocalizationProvider

If you find this library useful, cup of coffee would be awesome! You can support further development of the library via Paypal.

Localization Provider v8.0 IS OUT!

I'm pleased to announce that Localization Provider v8.0 is finally out. Again - took a bit longer than expected 😃

What's new?

  • .NET8 set as default target
  • Added provider model for translations - starting with Azure AI for automatic translations
  • ConfigurationContext now supports config configuration as well (you can change some settings after you have added and configured default settings for localization provider). This is very useful in unit test scenarios when you need to adjust some settings for specific test.
  • Various bug fixes
  • Some performance improvements (resource key comparison, pagination in Admin UI)
  • Security improvements (by default upgrading insecure connections)
  • Dependencies upgrade

More info in this blog post.

What is the LocalizationProvider project?

LocalizationProvider project is ASP.NET Mvc web application localization provider on steroids.

Giving you the main following features:

  • Database-driven localization provider for Asp.Net Mvc applications projects
  • Easy resource registrations via code
  • Supports hierarchical resource organization (with help of child classes)
  • Administration UI for editors to change or add new translations for required languages

Getting Started (.NET)

Bare Minimum to Start With

Below are code fragments that are essential to get started with a localization provider.

Install required packages:

> dotnet add package LocalizationProvider.AspNetCore
> dotnet add package LocalizationProvider.AdminUI.AspNetCore
> dotnet add package LocalizationProvider.Storage.SqlServer

Following service configuration (usually in Startup.cs) is required to get the localization provider working:

public class Startup
{
    public void ConfigureServices(IServiceCollection services)
    {
        // add your authorization provider (asp.net identity, identity server, whichever..)

        services
            .AddControllersWithViews()
            .AddMvcLocalization();

        services.AddRazorPages();
        services.AddRouting();

        services.AddDbLocalizationProvider(_ =>
        {
            _.UseSqlServer(Configuration.GetConnectionString("DefaultConnection"));
            ...
        });

        services.AddDbLocalizationProviderAdminUI(_ =>
        {
            ...
        });
    }

    ...
}

And following setup of the application is required as a minimum (also usually located in Startup.cs):

public class Startup
{
    ...

    public void Configure(IApplicationBuilder app, IHostingEnvironment env)
    {
        app.UseRouting();
        app.UseAuthentication();
        app.UseAuthorization();

        app.UseDbLocalizationProvider();
        app.UseDbLocalizationProviderAdminUI();
        app.UseDbLocalizationClientsideProvider(); //assuming that you like also Javascript

        app.UseEndpoints(endpoints =>
        {
            endpoints.MapControllers();
            endpoints.MapRazorPages();
            endpoints.MapDbLocalizationAdminUI();
            endpoints.MapDbLocalizationClientsideProvider();
        });
    }
}

Also, you can refer to sample app in GitHub for some more hints if needed.

More Detailed Help

Getting Started - Optimizely CMS/Commerce

Working with DbLocalizationProvider Stuff

Integrating with Optimizely

  • For more information about Optimizely integration - read here

Other Versions

Localization Provider v7.x Released

Please read more in this blog post!

More Info

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (20)

Showing the top 5 NuGet packages that depend on LocalizationProvider:

Package Downloads
LocalizationProvider.AspNet

LocalizationProvider support package for Asp.Net

LocalizationProvider.Storage.SqlServer

SqlServer storage implementation for DbLocalizationProvider package

LocalizationProvider.AspNetCore

Database driven localization provider. Asp.Net Core support package

LocalizationProvider.AdminUI.AspNetCore

Database driven localization provider. Admin UI for Asp.Net Core apps.

LocalizationProvider.AdminUI.Models

Abstractions for database driven localization provider AdminUI.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
8.2.4 1,972 12/28/2024
8.2.3 4,500 11/27/2024
8.2.2 2,414 11/15/2024
8.2.1 4,113 11/3/2024
8.2.0 10,172 9/23/2024
8.1.6 8,544 9/2/2024
8.1.5 9,033 8/27/2024
8.1.4 7,673 8/15/2024
8.1.3 1,994 8/13/2024
8.1.2 1,026 8/7/2024
8.1.1 351 8/4/2024
8.1.0 11,849 6/5/2024
8.0.3 11,216 5/5/2024
8.0.2 9,364 3/28/2024
8.0.1 4,855 3/5/2024
8.0.0 7,574 2/17/2024
7.5.2 51,488 12/23/2023
7.5.1 124,459 1/1/2023
7.5.0 23,308 11/12/2022
7.4.0 15,372 9/29/2022
7.3.1 38,417 8/30/2022
7.3.0 22,749 6/9/2022
7.2.1 25,969 3/17/2022
7.2.0 17,957 3/3/2022
7.1.0 7,422 2/10/2022
7.0.0 14,249 1/23/2022
7.0.0-pre-0015 1,322 1/19/2022
7.0.0-pre-0014 1,259 1/16/2022
7.0.0-pre-0013 1,547 12/27/2021
7.0.0-pre-0012 1,446 11/30/2021
7.0.0-pre-0011 2,681 11/26/2021
7.0.0-pre-0010 6,467 11/24/2021
7.0.0-pre-0008 5,687 11/24/2021
7.0.0-pre-0007 7,372 11/23/2021
7.0.0-pre-0006 2,640 10/31/2021
7.0.0-pre-0005 2,120 10/17/2021
7.0.0-pre-0004 1,685 10/4/2021
7.0.0-pre-0003 1,888 9/12/2021
7.0.0-pre-0002 1,642 8/30/2021
7.0.0-pre-0001 1,881 7/25/2021
6.5.3 13,226 5/22/2023
6.5.2 31,363 2/27/2022
6.5.1 2,036 2/27/2022
6.5.0 66,160 5/7/2021
6.4.0 22,568 12/22/2020
6.3.0 6,680 10/27/2020
6.2.2 12,614 9/9/2020
6.2.1 3,142 9/9/2020
6.2.0 39,822 7/9/2020
6.1.0 5,482 6/9/2020
6.0.2 15,438 3/17/2020
6.0.1 2,685 3/16/2020
6.0.0 2,781 2/21/2020
5.8.2 118,722 1/29/2020
5.7.7 38,475 11/23/2019
5.7.5 36,642 9/29/2019
5.7.4 20,854 9/14/2019
5.7.3 5,820 8/16/2019
5.7.1 32,201 7/14/2019
5.7.0 3,097 6/30/2019
5.6.0 12,643 5/7/2019
5.5.1 8,698 4/19/2019
5.5.0 5,905 4/8/2019
5.4.0 13,174 2/28/2019
5.3.3 929 2/27/2019
5.3.2 1,533 2/27/2019
5.3.1 852 2/22/2019
5.3.0 7,331 2/10/2019
5.1.0 3,880 1/13/2019
5.0.0 22,219 10/18/2018
4.2.2 43,592 4/4/2018
4.2.1 1,248 3/30/2018
4.2.0 2,242 3/3/2018
4.1.0 10,349 1/23/2018
4.0.0 2,834 12/29/2017
2.11.3 4,996 12/21/2017
2.11.2 1,211 12/19/2017
2.11.1 1,990 12/6/2017
2.11.0 1,628 12/2/2017
2.10.0 1,852 11/26/2017
2.9.2 1,226 11/24/2017
2.9.1 1,777 11/15/2017
2.9.0 18,881 10/9/2017
2.8.3 1,945 9/13/2017
2.8.2 2,041 8/26/2017
2.8.1 1,677 8/19/2017
2.8.0 2,424 8/15/2017
2.7.0 4,833 7/5/2017
2.6.2 2,265 6/8/2017
2.6.1 1,660 5/22/2017
2.6.0 3,357 4/24/2017
2.5.2 1,127 4/8/2017
2.5.1 1,584 3/31/2017
2.5.0 2,578 3/19/2017
2.4.2 1,291 3/17/2017
2.4.1 1,314 2/24/2017
2.4.0 1,226 2/22/2017
2.3.2 1,609 6/8/2017
2.3.1 1,633 5/22/2017
2.3.0 5,018 2/16/2017
2.2.5 1,438 1/5/2017
2.2.4 1,361 12/23/2016
2.2.3 1,303 12/15/2016
2.2.2 1,202 12/8/2016
2.2.1 1,206 12/6/2016
2.2.0 1,403 12/2/2016
2.1.2 1,242 11/17/2016
2.1.1 1,483 11/12/2016
2.1.0 1,711 11/3/2016
2.0.4 1,526 9/4/2016
2.0.3 1,154 8/24/2016
2.0.2 1,438 7/27/2016
2.0.1 1,239 6/7/2016
2.0.0 3,294 6/4/2016