Aiursoft.Dotlang 9.0.1

There is a newer version of this package available.
See the version list below for details.
dotnet tool install --global Aiursoft.Dotlang --version 9.0.1                
This package contains a .NET tool you can call from the shell/command line.
dotnet new tool-manifest # if you are setting up this repo
dotnet tool install --local Aiursoft.Dotlang --version 9.0.1                
This package contains a .NET tool you can call from the shell/command line.
#tool dotnet:?package=Aiursoft.Dotlang&version=9.0.1                
nuke :add-package Aiursoft.Dotlang --version 9.0.1                

ASP.NET Core App Translator

MIT licensed Pipeline stat Test Coverage NuGet version (Aiursoft.DotLang) ManHours

This app helps you generate translated .cshtml files and resources files.

How to install

Requirements:

  1. .NET 9 SDK

Run the following command to install this tool:

dotnet tool install --global Aiursoft.Dotlang

How does it works

  • Find all files ends with .cshtml
  • foreach cshtml file, replace all text in tag sround with @Localizer[""]
  • Call bing translate API to translate all those content
  • Save the translated file as Resource file in the Resources folder.

The Core Translator won't override any existing translation nor resources files. If your content was already surrounded with @Localizer[""], we won't touch it.

How to run locally

Build:

dotnet pack

Install:

dotnet tool install --global --add-source ./nupkg dotlang

Run:

# In your project folder
$ dotlang

Uninstall:

dotnet tool uninstall -g dotlang

Before running the translator

Use the following code to register the localizer service:

// In StartUp.cs ConfigureServices method:
services.AddLocalization(options => options.ResourcesPath = "Resources");

services.AddMvc()
    .AddViewLocalization(LanguageViewLocationExpanderFormat.Suffix)
    .AddDataAnnotationsLocalization();

Use the following code to add localizer middleware:

// In StartUp.cs Configure method
var SupportedCultures = new CultureInfo[]
{
    new CultureInfo("en"),
    new CultureInfo("zh")
};
app.UseRequestLocalization(new RequestLocalizationOptions
{
    DefaultRequestCulture = new RequestCulture(defaultLanguage),
    SupportedCultures = SupportedCultures,
    SupportedUICultures = SupportedCultures
});

Use the following code to inject localizer:

@using Microsoft.AspNetCore.Mvc.Localization
@inject IViewLocalizer Localizer
@addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers

Now run this app!

Caution

Running this under your project folder may ruin your project! It may change your cshtml! Do run git commit under your project before running this app.

Product Compatible and additional computed target framework versions.
.NET net9.0 is compatible.  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.

This package has no dependencies.

Version Downloads Last updated
9.0.2 66 1/16/2025
9.0.1 41 1/15/2025
9.0.0 88 1/2/2025
8.0.13 92 1/1/2025
8.0.12 118 10/10/2024
8.0.11 104 10/9/2024
8.0.10 88 10/7/2024
8.0.9 97 10/5/2024
8.0.8 108 8/30/2024
8.0.7 97 7/31/2024
8.0.6 109 7/12/2024
8.0.5 89 7/10/2024
8.0.4 110 6/29/2024
8.0.3 106 6/28/2024
8.0.2 106 6/18/2024
8.0.1 113 6/5/2024
8.0.0 1,124 2/19/2024
7.0.11 1,355 2/2/2024
7.0.10 1,445 1/30/2024
7.0.9 1,978 12/12/2023
7.0.8 2,023 12/12/2023
7.0.6 2,255 12/6/2023
7.0.5 2,243 12/6/2023
7.0.4 2,205 12/6/2023
7.0.3 2,070 11/12/2023
7.0.2 2,548 11/2/2023
7.0.1 2,416 11/2/2023
7.0.0 2,803 9/7/2023
6.0.2 2,956 7/20/2023
6.0.1 2,804 5/18/2023