19de52e0f4
Follow #21429 & #22861 Use `<gitea-locale-number>` instead of backend `PrettyNumber`. All old `PrettyNumber` related functions are removed. A lot of code could be simplified. And some functions haven't been used for long time (dead code), so they are also removed by the way (eg: `SplitStringAtRuneN`, `Dedent`) This PR only tries to improve the `PrettyNumber` rendering problem, it doesn't touch the "plural" problem. Screenshot: ![image](https://user-images.githubusercontent.com/2114189/229290804-1f63db65-1e34-4a54-84ba-e00b44331b17.png) ![image](https://user-images.githubusercontent.com/2114189/229290911-c88dea00-b11d-48dd-accb-9f52edd73ce4.png)
31 lines
1.2 KiB
JavaScript
31 lines
1.2 KiB
JavaScript
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() {
|
|
// 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');
|
|
}
|
|
}
|