mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-25 03:22:36 +00:00 
			
		
		
		
	- Replace all default exports with named exports, except for Vue SFCs - Remove names from Vue SFCs, they are automatically inferred from the filename - Misc whitespace-related tweaks
		
			
				
	
	
		
			42 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			42 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');
 | |
|   }
 | |
| }
 |