Skip to content
Closed
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
103 changes: 78 additions & 25 deletions public/banner.js
Original file line number Diff line number Diff line change
Expand Up @@ -66,27 +66,79 @@
var params = getScriptParams();

// ── Determine locale ──────────────────────────────────────────────────
function resolveLocale(tag) {
if (!tag) return "en";
if (messages[tag]) return tag;
var lower = tag.toLowerCase();
for (var key in messages) {
if (key.toLowerCase() === lower) return key;
function getBestLocale(desired, available) {
Comment thread
ray2c marked this conversation as resolved.
Outdated
var dLen = 0;
if (!desired || !(dLen = desired.length) || !available) return null;

var d = new Array(dLen);
var dS = new Array(dLen);
var dC = new Array(dLen);

function matchLang(k, d) {
var kLen = k.length;
var dLen = d.length;
var kChr;
var dChr;
var kBal;
var dBal;
for (var i = 0; (kBal = i < kLen && (kChr = k[i]) !== '-') & (dBal = i < dLen && (dChr = d[i]) !== '-'); i++) {
if (kChr !== dChr && kChr.toLowerCase() !== dChr.toLowerCase()) return ~i;
}
return kBal || dBal ? ~i : i;
}
var base = tag.split("-")[0].toLowerCase();
if (messages[base]) return base;
for (var key2 in messages) {
if (key2.toLowerCase().split("-")[0] === base) return key2;

var b = null;
var bW = null;
for (var key in available) {
var a = null;
var s = null;
var prio = -1;
var l = null;
var script = null;
for (var i = 0; i < dLen; i++) {
var sep = matchLang(key, desired[i]);
if (sep < 0) continue;
if (!a) try {
a = new Intl.Locale(key);
s = a.script || a.maximize().script;
} catch (e) {}
l = d[i];
try {
script = l ? l.script || dS[i] : (l = d[i] = new Intl.Locale(desired[i])).script || (dS[i] ||= l.maximize().script);
} catch (e) {}
if (script === s) {
prio = i;
break;
}
}
if (prio < 0) continue;
s = a.script;
var c = a.region;
var w = prio << 5 | (sep + (s ? s.length + 1 : 0) + (c ? c.length + 1 : 0) != key.length) << 4;
if ((s && l.script || c && l.region) && c === l.region) {
w |= !s | !c << 1 | !(s === l.script) << 2;
} else {
w |= 8 | !!c << 2 | !!s << 1;
if (c) try {
w |= c !== (dC[prio] ||= new Intl.Locale(d[prio].language, { script: script }).maximize().region);
} catch (e) {}
}
if (bW === null || w < bW) {
b = key;
bW = w;
}
}
return "en";
return b;
}

var locale = resolveLocale(
params.lang ||
var locales = navigator.languages;
var preferred = params.lang ||
document.documentElement.lang ||
navigator.language ||
navigator.userLanguage
);
navigator.userLanguage;
if (!locales || !locales.length || preferred !== locales[0]) locales = [...preferred.split(',').map(p => p.trim()), ...locales];

var locale = messages[locales[0]] ? locales[0] : getBestLocale(locales, messages) || 'en';

// ── Size variant ──────────────────────────────────────────────────────
var size = params.size === "mini" ? "mini" : "normal";
Expand Down Expand Up @@ -295,19 +347,19 @@
}
}

cacheFormattingInfo(1, "day");
cacheFormattingInfo(2, "hour");
cacheFormattingInfo(3, "minute");
cacheFormattingInfo(4, "second");
cacheFormattingInfo(11, "day");
cacheFormattingInfo(22, "hour");
cacheFormattingInfo(33, "minute");
cacheFormattingInfo(44, "second");

function getLocalizedUnit(value, unit, trimConjunction, trimSuffix) {
var offset = getOffset(unit);
var string = formatter.format(value, unit);
var p = pfx[offset];
var s = sfx[offset];
return string.slice(
trimConjunction && p || (p == 1 && string[0] === "+") ? pfx[offset] : 0,
trimSuffix && s ? -sfx[offset] : string.length
trimConjunction && p || (p == 1 && string[0] === "+") ? p : 0,
trimSuffix && s ? -s : string.length
);
}

Expand All @@ -319,6 +371,11 @@
var now = new Date().getTime();
var distance = countDownDate - now;

if (distance < 0) {
clearInterval(timer);
return;
}

var days = Math.floor(distance / (1000 * 60 * 60 * 24));
var hours = Math.floor(
(distance % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60)
Expand All @@ -342,10 +399,6 @@
remaining[6] = getLocalizedUnit(seconds, "second", parts++, false);

countdownSpan.textContent = remaining.join("");

if (distance < 0) {
clearInterval(timer);
}
}

timer = setInterval(updateBanner, 1000);
Expand Down