pvWay.ExcelTranslationProvider.Core
1.0.0
dotnet add package pvWay.ExcelTranslationProvider.Core --version 1.0.0
NuGet\Install-Package pvWay.ExcelTranslationProvider.Core -Version 1.0.0
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="pvWay.ExcelTranslationProvider.Core" Version="1.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add pvWay.ExcelTranslationProvider.Core --version 1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: pvWay.ExcelTranslationProvider.Core, 1.0.0"
#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 pvWay.ExcelTranslationProvider.Core as a Cake Addin #addin nuget:?package=pvWay.ExcelTranslationProvider.Core&version=1.0.0 // Install pvWay.ExcelTranslationProvider.Core as a Cake Tool #tool nuget:?package=pvWay.ExcelTranslationProvider.Core&version=1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Excel Translations Provider for .Net Core by pvWay
Summary
The package contains two assets.
- A service that browses a given directory gathering excel files for building a translations dictionary.
- A cache singleton that refreshes when one Excel translation file in updated.
Excel Translation file structure
The Excel Translation file should contain one WorkSheet with the following rows
- Row 1 (header row) : KeyPart1 | KeyPart2 | KeyPart3 | KeyPart4 | IsoLanguageCode1 | IsoLanguageCode2...
- example
- K1 | K2 | K3 | K4 | en | fr | nl
- Rows 2 to N : the keys and the corresponding translations
- example
- Buttons | Add | . | . | Add | Ajouter | Toevoeggen
Based on the data here above the Translation Service will construct the following dictionary
{ 'Alpha.Buttons.Add', {'en':'Add', 'fr':'Ajouter', 'nl':'Toevoegen' }
Where
- 'Alpha' is the name of the Worksheet tab
- 'Button' is taken from row 2 (first data row), col 1
- Add is taken from row 2 (first data row), col 2
- row 2, col2 and col3 are empty and thereof not participating to the construction of the key
So the key is 'Alpha.Buttons.Add' and is case sensitive
For the values
- 'en' is taken from row1 (header row) col 5
- 'Add' is taken from row2 (data row) col 5
- 'fr' is taken from row1 (header row) col 6
- 'Ajouter' is taken from row2 (data row) col 6
- 'nl' is taken from row1 (header row) col 7
- 'Toevoegen' is taken from row2 (data row) col 7
The result is a IDicionary <string, IDictionary <string, string>>
Usage
using System;
using pvWay.ExcelTranslationProvider.Core;
namespace ExcelTranslationProviderConsole.Core
{
internal static class Program
{
private static void Main(/*string[] args*/)
{
var excelTranslationService = new ExcelTranslationService(
Console.WriteLine, // for logging any issue
"..\\..\\..\\MyExcelTranslationsFolder", // the path to the directory
"trans_*.xlsx" // the filename skeleton
);
// we can get the file modification date of the most recent Excel
var lastUpdateDate = excelTranslationService.LastUpdateDateUtc;
Console.WriteLine($"last update date in folder = {lastUpdateDate:dd MMM yyyy HH:mm:ss}");
// we can retrieve a IDictionary<string, IDictionary<string, string>
// containing all the translations
var translations = excelTranslationService.ReadTranslations();
foreach (var (key, dictionary) in translations)
{
Console.Write($"{key} =>");
foreach (var (languageCode, translation) in dictionary)
{
Console.Write($" {languageCode} - {translation} ");
}
Console.Write("\n");
}
// There is also a Cache Singleton that you can instantiate any where
// When in place you get any translation for a given key
var tc = ExcelTranslationCacheSingleton
.GetInstance(excelTranslationService, TimeSpan.FromMinutes(5));
var addButtonLiteral = tc.GetTranslation("en", "Alpha.buttons.add");
Console.WriteLine(addButtonLiteral);
Console.WriteLine("hit enter to quit");
Console.ReadLine();
}
}
}
Interfaces
public interface IExcelTranslationCache
{
/// <summary>
/// With this date any data consumer can verify
/// whether or not its cached copy of the dictionary
/// is still up to date and if needed refresh the
/// cache by getting the Translation property.
/// </summary>
/// <returns></returns>
DateTime LastUpdateDateUtc { get; }
/// <summary>
/// The key is build from the concatenation of
/// up to 4 key parts separated by dots. Example: 'components.buttons.save').
/// The associated value is dictionary languageCode:string
/// </summary>
IDictionary<string, IDictionary<string, string>> Translations { get; }
void RefreshNow();
/// <summary>
/// key string should contain the keys separated by dots. example : 'enum.size'
/// </summary>
/// <param name="languageCode"></param>
/// <param name="keysString"></param>
/// <returns></returns>
string GetTranslation(string languageCode, string keysString);
}
/// <summary>
/// This service provides the mechanism for managing a cached
/// translation dictionary at data consumer side
/// </summary>
public interface IExcelTranslationService : IDisposable
{
/// <summary>
/// With this date any data consumer can verify
/// whether or not its cached copy of the dictionary
/// is still up to date and if needed refresh the
/// cache by getting the Translation property.
/// </summary>
/// <returns></returns>
DateTime LastUpdateDateUtc { get; }
/// <summary>
/// The key is build from the concatenation of
/// up to 4 key parts separated by dots. Example: 'components.buttons.save').
/// The associated value is dictionary languageCode:string
/// </summary>
IDictionary<string, IDictionary<string, string>> ReadTranslations();
}
Happy coding 😃
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. |
.NET Core | netcoreapp3.1 is compatible. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETCoreApp 3.1
- ExcelDataReader (>= 3.6.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.0.0 | 2,691 | 3/7/2021 |
initial