mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 08:30:25 +08:00 
			
		
		
		
	- 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>
		
			
				
	
	
		
			111 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			111 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2017 The Gitea Authors. All rights reserved.
 | 
						|
// SPDX-License-Identifier: MIT
 | 
						|
 | 
						|
package timeutil
 | 
						|
 | 
						|
import (
 | 
						|
	"time"
 | 
						|
 | 
						|
	"code.gitea.io/gitea/modules/setting"
 | 
						|
)
 | 
						|
 | 
						|
// TimeStamp defines a timestamp
 | 
						|
type TimeStamp int64
 | 
						|
 | 
						|
var (
 | 
						|
	// mock is NOT concurrency-safe!!
 | 
						|
	mock time.Time
 | 
						|
 | 
						|
	// Used for IsZero, to check if timestamp is the zero time instant.
 | 
						|
	timeZeroUnix = time.Time{}.Unix()
 | 
						|
)
 | 
						|
 | 
						|
// Set sets the time to a mocked time.Time
 | 
						|
func Set(now time.Time) {
 | 
						|
	mock = now
 | 
						|
}
 | 
						|
 | 
						|
// Unset will unset the mocked time.Time
 | 
						|
func Unset() {
 | 
						|
	mock = time.Time{}
 | 
						|
}
 | 
						|
 | 
						|
// TimeStampNow returns now int64
 | 
						|
func TimeStampNow() TimeStamp {
 | 
						|
	if !mock.IsZero() {
 | 
						|
		return TimeStamp(mock.Unix())
 | 
						|
	}
 | 
						|
	return TimeStamp(time.Now().Unix())
 | 
						|
}
 | 
						|
 | 
						|
// Add adds seconds and return sum
 | 
						|
func (ts TimeStamp) Add(seconds int64) TimeStamp {
 | 
						|
	return ts + TimeStamp(seconds)
 | 
						|
}
 | 
						|
 | 
						|
// AddDuration adds time.Duration and return sum
 | 
						|
func (ts TimeStamp) AddDuration(interval time.Duration) TimeStamp {
 | 
						|
	return ts + TimeStamp(interval/time.Second)
 | 
						|
}
 | 
						|
 | 
						|
// Year returns the time's year
 | 
						|
func (ts TimeStamp) Year() int {
 | 
						|
	return ts.AsTime().Year()
 | 
						|
}
 | 
						|
 | 
						|
// AsTime convert timestamp as time.Time in Local locale
 | 
						|
func (ts TimeStamp) AsTime() (tm time.Time) {
 | 
						|
	return ts.AsTimeInLocation(setting.DefaultUILocation)
 | 
						|
}
 | 
						|
 | 
						|
// AsLocalTime convert timestamp as time.Time in local location
 | 
						|
func (ts TimeStamp) AsLocalTime() time.Time {
 | 
						|
	return time.Unix(int64(ts), 0)
 | 
						|
}
 | 
						|
 | 
						|
// AsTimeInLocation convert timestamp as time.Time in Local locale
 | 
						|
func (ts TimeStamp) AsTimeInLocation(loc *time.Location) time.Time {
 | 
						|
	return time.Unix(int64(ts), 0).In(loc)
 | 
						|
}
 | 
						|
 | 
						|
// AsTimePtr convert timestamp as *time.Time in Local locale
 | 
						|
func (ts TimeStamp) AsTimePtr() *time.Time {
 | 
						|
	return ts.AsTimePtrInLocation(setting.DefaultUILocation)
 | 
						|
}
 | 
						|
 | 
						|
// AsTimePtrInLocation convert timestamp as *time.Time in customize location
 | 
						|
func (ts TimeStamp) AsTimePtrInLocation(loc *time.Location) *time.Time {
 | 
						|
	tm := time.Unix(int64(ts), 0).In(loc)
 | 
						|
	return &tm
 | 
						|
}
 | 
						|
 | 
						|
// Format formats timestamp as given format
 | 
						|
func (ts TimeStamp) Format(f string) string {
 | 
						|
	return ts.FormatInLocation(f, setting.DefaultUILocation)
 | 
						|
}
 | 
						|
 | 
						|
// FormatInLocation formats timestamp as given format with spiecific location
 | 
						|
func (ts TimeStamp) FormatInLocation(f string, loc *time.Location) string {
 | 
						|
	return ts.AsTimeInLocation(loc).Format(f)
 | 
						|
}
 | 
						|
 | 
						|
// FormatLong formats as RFC1123Z
 | 
						|
func (ts TimeStamp) FormatLong() string {
 | 
						|
	return ts.Format(time.RFC1123Z)
 | 
						|
}
 | 
						|
 | 
						|
// FormatShort formats as short
 | 
						|
func (ts TimeStamp) FormatShort() string {
 | 
						|
	return ts.Format("Jan 02, 2006")
 | 
						|
}
 | 
						|
 | 
						|
// FormatDate formats a date in YYYY-MM-DD server time zone
 | 
						|
func (ts TimeStamp) FormatDate() string {
 | 
						|
	return time.Unix(int64(ts), 0).String()[:10]
 | 
						|
}
 | 
						|
 | 
						|
// IsZero is zero time
 | 
						|
func (ts TimeStamp) IsZero() bool {
 | 
						|
	return int64(ts) == 0 || int64(ts) == timeZeroUnix
 | 
						|
}
 |