mirror of
				https://github.com/go-gitea/gitea
				synced 2025-11-04 05:18:25 +00:00 
			
		
		
		
	Use auto-updating, natively hoverable, localized time elements (#23988)
- Added [GitHub's `relative-time` element](https://github.com/github/relative-time-element) - Converted all formatted timestamps to use this element - No more flashes of unstyled content around time elements - These elements are localized using the `lang` property of the HTML file - Relative (e.g. the activities in the dashboard) and duration (e.g. server uptime in the admin page) time elements are auto-updated to keep up with the current time without refreshing the page - Code that is not needed anymore such as `formatting.js` and parts of `since.go` have been deleted Replaces #21440 Follows #22861 ## Screenshots ### Localized   ### Tooltips #### Native for dates  #### Interactive for relative  ### Auto-update  --------- Signed-off-by: Yarden Shoham <git@yardenshoham.com> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com> Co-authored-by: silverwind <me@silverwind.io> Co-authored-by: delvh <dev.lh@web.de>
This commit is contained in:
		@@ -178,7 +178,7 @@ export function initAdminCommon() {
 | 
			
		||||
    // Attach view detail modals
 | 
			
		||||
    $('.view-detail').on('click', function () {
 | 
			
		||||
      $detailModal.find('.content pre').text($(this).parents('tr').find('.notice-description').text());
 | 
			
		||||
      $detailModal.find('.sub.header').text($(this).parents('tr').find('.notice-created-time').text());
 | 
			
		||||
      $detailModal.find('.sub.header').text($(this).parents('tr').find('relative-time').attr('title'));
 | 
			
		||||
      $detailModal.modal('show');
 | 
			
		||||
      return false;
 | 
			
		||||
    });
 | 
			
		||||
 
 | 
			
		||||
@@ -1,31 +0,0 @@
 | 
			
		||||
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');
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user