More robust language caching

This commit is contained in:
Thomas Hounsell 2016-08-21 16:15:33 +01:00
parent df5dd2fd4b
commit 7901300c30
5 changed files with 39 additions and 26 deletions

View File

@ -1,4 +1,6 @@
using System.Globalization; using System.Globalization;
using System.Linq;
using System.Web;
namespace BuildFeed.Code.Options namespace BuildFeed.Code.Options
{ {
@ -39,6 +41,8 @@ namespace BuildFeed.Code.Options
new Locale("zh-hant") new Locale("zh-hant")
}; };
private const string LANG_COOKIE_NAME = "bf_lang";
public string DisplayName => Info.NativeName; public string DisplayName => Info.NativeName;
public CultureInfo Info { get; set; } public CultureInfo Info { get; set; }
@ -49,5 +53,31 @@ namespace BuildFeed.Code.Options
LocaleId = localeId; LocaleId = localeId;
Info = CultureInfo.GetCultureInfo(localeId); Info = CultureInfo.GetCultureInfo(localeId);
} }
public static CultureInfo DetectCulture(HttpContextBase context)
{
string langCookie = context.Request.Cookies[LANG_COOKIE_NAME]?.Value;
if (!string.IsNullOrEmpty(langCookie))
{
try
{
CultureInfo ci = (CultureInfo)CultureInfo.GetCultureInfo(langCookie).Clone();
// Get Gregorian Calendar in locale if available
Calendar gc = ci.OptionalCalendars.FirstOrDefault(c => c is GregorianCalendar && ((GregorianCalendar)c).CalendarType == GregorianCalendarTypes.Localized);
if (gc != null)
{
ci.DateTimeFormat.Calendar = gc;
}
return ci;
}
catch (CultureNotFoundException) { }
}
return CultureInfo.CurrentCulture;
}
} }
} }

View File

@ -9,31 +9,11 @@ namespace BuildFeed.Controllers
{ {
public class BaseController : Controller public class BaseController : Controller
{ {
private const string LANG_COOKIE_NAME = "bf_lang";
protected override void Initialize(RequestContext requestContext) protected override void Initialize(RequestContext requestContext)
{ {
string langCookie = requestContext.HttpContext.Request.Cookies[LANG_COOKIE_NAME]?.Value; CultureInfo ci = Locale.DetectCulture(requestContext.HttpContext);
if (!string.IsNullOrEmpty(langCookie))
{
try
{
CultureInfo ci = (CultureInfo)CultureInfo.GetCultureInfo(langCookie).Clone();
// Get Gregorian Calendar in locale if available
Calendar gc = ci.OptionalCalendars.FirstOrDefault(c => c is GregorianCalendar && ((GregorianCalendar)c).CalendarType == GregorianCalendarTypes.Localized);
if (gc != null)
{
ci.DateTimeFormat.Calendar = gc;
}
CultureInfo.CurrentCulture = ci; CultureInfo.CurrentCulture = ci;
CultureInfo.CurrentUICulture = ci; CultureInfo.CurrentUICulture = ci;
}
catch (CultureNotFoundException) { }
}
ViewBag.Theme = new Theme(Theme.DetectTheme(requestContext.HttpContext)); ViewBag.Theme = new Theme(Theme.DetectTheme(requestContext.HttpContext));

View File

@ -37,6 +37,7 @@ namespace BuildFeed
{ {
string[] parts = custom.Split(';'); string[] parts = custom.Split(';');
List<string> varyParts = new List<string>(); List<string> varyParts = new List<string>();
HttpContextWrapper contextWrapper = new HttpContextWrapper(context);
foreach (string part in parts) foreach (string part in parts)
{ {
@ -46,10 +47,10 @@ namespace BuildFeed
varyParts.Add($"user:{context.User.Identity.Name}"); varyParts.Add($"user:{context.User.Identity.Name}");
break; break;
case "lang": case "lang":
varyParts.Add($"lang:{CultureInfo.CurrentUICulture.LCID}"); varyParts.Add($"lang:{Locale.DetectCulture(contextWrapper).LCID}");
break; break;
case "theme": case "theme":
varyParts.Add($"theme:{Theme.DetectTheme(new HttpContextWrapper(context))}"); varyParts.Add($"theme:{Theme.DetectTheme(contextWrapper)}");
break; break;
} }
} }

View File

@ -1,3 +1,5 @@
/// <reference path="../../scripts/typings/google.analytics/ga.d.ts" />
/// <reference path="../../scripts/typings/jsrender/jsrender.d.ts" />
var BuildFeed; var BuildFeed;
(function (BuildFeed) { (function (BuildFeed) {
var ajax; var ajax;

File diff suppressed because one or more lines are too long