mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-10 15:31:10 -05:00
acdb92ad42
Following * #21410 We are now able to localize all timestamps. Some examples: `short-date` format, French, user profile page: ![image](https://user-images.githubusercontent.com/20454870/195622461-aa0d5b93-f8df-42ad-881c-9c16606bf387.png) `date-time` format, Portuguese, mirror repository settings page: ![image](https://user-images.githubusercontent.com/20454870/195623191-7a37d77c-4a02-4140-846d-f290a65ea21d.png) Signed-off-by: Yarden Shoham <hrsi88@gmail.com> Signed-off-by: Yarden Shoham <hrsi88@gmail.com> Co-authored-by: Gusted <williamzijl7@hotmail.com> Co-authored-by: techknowlogick <techknowlogick@gitea.io> Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
43 lines
1.6 KiB
JavaScript
43 lines
1.6 KiB
JavaScript
import {prettyNumber} from '../utils.js';
|
|
|
|
const {lang} = document.documentElement;
|
|
|
|
const dateFormatter = new Intl.DateTimeFormat(lang, {year: 'numeric', month: 'long', day: 'numeric'});
|
|
const shortDateFormatter = new Intl.DateTimeFormat(lang, {year: 'numeric', month: 'short', day: 'numeric'});
|
|
const dateTimeFormatter = new Intl.DateTimeFormat(lang, {year: 'numeric', month: 'short', day: 'numeric', hour: 'numeric', minute: 'numeric', second: 'numeric'});
|
|
|
|
export function initFormattingReplacements() {
|
|
// replace english formatted numbers with locale-specific separators
|
|
for (const el of document.getElementsByClassName('js-pretty-number')) {
|
|
const num = Number(el.getAttribute('data-value'));
|
|
const formatted = prettyNumber(num, lang);
|
|
if (formatted && formatted !== el.textContent) {
|
|
el.textContent = formatted;
|
|
}
|
|
}
|
|
|
|
// for each <time></time> tag, if it has the data-format attribute, format
|
|
// the text according to the user's chosen locale and formatter.
|
|
formatAllTimeElements();
|
|
}
|
|
|
|
function formatAllTimeElements() {
|
|
const timeElements = document.querySelectorAll('time[data-format]');
|
|
for (const timeElement of timeElements) {
|
|
const formatter = getFormatter(timeElement.dataset.format);
|
|
timeElement.textContent = formatter.format(new Date(timeElement.dateTime));
|
|
}
|
|
}
|
|
|
|
function getFormatter(format) {
|
|
switch (format) {
|
|
case 'date':
|
|
return dateFormatter;
|
|
case 'short-date':
|
|
return shortDateFormatter;
|
|
case 'date-time':
|
|
return dateTimeFormatter;
|
|
default:
|
|
throw new Error('Unknown format');
|
|
}
|
|
}
|