Merge pull request #63 from oqtane/master

sync
This commit is contained in:
Shaun Walker
2020-11-09 08:29:14 -05:00
committed by GitHub

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);
} }
} }