Merge pull request #870 from hishamco/localization

Use IStringLocalizerFactory for simplicity
This commit is contained in:
Shaun Walker 2020-11-08 14:58:42 -05:00 committed by GitHub
commit 780b0c704c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1,5 +1,6 @@
using System; using System;
using Microsoft.AspNetCore.Components; using Microsoft.AspNetCore.Components;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Localization; using Microsoft.Extensions.Localization;
using Oqtane.Shared; using Oqtane.Shared;
@ -33,13 +34,12 @@ namespace Oqtane.Modules.Controls
if (ModuleState?.ModuleType != null) if (ModuleState?.ModuleType != null)
{ {
var moduleType = Type.GetType(ModuleState.ModuleType); var moduleType = Type.GetType(ModuleState.ModuleType);
var localizerTypeName = $"Microsoft.Extensions.Localization.IStringLocalizer`1[[{moduleType.AssemblyQualifiedName}]], Microsoft.Extensions.Localization.Abstractions";
var localizerType = Type.GetType(localizerTypeName);
// HACK: Use ServiceActivator instead of injecting IHttpContextAccessor, because HttpContext throws NRE in WebAssembly runtime // HACK: Use ServiceActivator instead of injecting IHttpContextAccessor, because HttpContext throws NRE in WebAssembly runtime
using (var scope = ServiceActivator.GetScope()) using (var scope = ServiceActivator.GetScope())
{ {
_localizer = (IStringLocalizer)scope.ServiceProvider.GetService(localizerType); var localizerFactory = scope.ServiceProvider.GetService<IStringLocalizerFactory>();
_localizer = localizerFactory.Create(moduleType);
} }
} }