mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-04 13:34:43 +01:00 
			
		
		
		
	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:  
		
			
				
	
	
		
			32 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			32 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');
 | 
						|
  }
 | 
						|
}
 |