mirror of https://github.com/Chocobozzz/PeerTube
Better seconds to time formatting
parent
9b70c8e7e8
commit
61fec4e4ef
|
@ -320,11 +320,11 @@ export class VideoStatsComponent implements OnInit {
|
||||||
this.overallStatCards = [
|
this.overallStatCards = [
|
||||||
{
|
{
|
||||||
label: $localize`Average watch time`,
|
label: $localize`Average watch time`,
|
||||||
value: secondsToTime(overallStats.averageWatchTime)
|
value: secondsToTime({ seconds: overallStats.averageWatchTime, format: 'locale-string' })
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: $localize`Total watch time`,
|
label: $localize`Total watch time`,
|
||||||
value: secondsToTime(overallStats.totalWatchTime)
|
value: secondsToTime({ seconds: overallStats.totalWatchTime, format: 'locale-string' })
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: $localize`Peak viewers`,
|
label: $localize`Peak viewers`,
|
||||||
|
|
|
@ -40,7 +40,7 @@ export class TimestampInputComponent implements ControlValueAccessor, OnInit {
|
||||||
writeValue (timestamp: number) {
|
writeValue (timestamp: number) {
|
||||||
this.timestamp = timestamp
|
this.timestamp = timestamp
|
||||||
|
|
||||||
this.timestampString = secondsToTime({ seconds: this.timestamp, fullFormat: true, symbol: ':' })
|
this.timestampString = secondsToTime({ seconds: this.timestamp, format: 'full', symbol: ':' })
|
||||||
}
|
}
|
||||||
|
|
||||||
registerOnChange (fn: (_: any) => void) {
|
registerOnChange (fn: (_: any) => void) {
|
||||||
|
|
|
@ -174,8 +174,8 @@ export class VideoPlaylistElementMiniatureComponent implements OnInit {
|
||||||
const start = playlistElement.startTimestamp
|
const start = playlistElement.startTimestamp
|
||||||
const stop = playlistElement.stopTimestamp
|
const stop = playlistElement.stopTimestamp
|
||||||
|
|
||||||
const startFormatted = secondsToTime({ seconds: start, fullFormat: true, symbol: ':' })
|
const startFormatted = secondsToTime({ seconds: start, format: 'full', symbol: ':' })
|
||||||
const stopFormatted = secondsToTime({ seconds: stop, fullFormat: true, symbol: ':' })
|
const stopFormatted = secondsToTime({ seconds: stop, format: 'full', symbol: ':' })
|
||||||
|
|
||||||
if (start === null && stop === null) return ''
|
if (start === null && stop === null) return ''
|
||||||
|
|
||||||
|
|
|
@ -85,48 +85,55 @@ function timeToInt (time: number | string) {
|
||||||
|
|
||||||
function secondsToTime (options: {
|
function secondsToTime (options: {
|
||||||
seconds: number
|
seconds: number
|
||||||
fullFormat?: boolean // default false
|
format: 'short' | 'full' | 'locale-string' // default 'short'
|
||||||
symbol?: string
|
symbol?: string
|
||||||
} | number) {
|
} | number) {
|
||||||
let seconds: number
|
let seconds: number
|
||||||
let fullFormat = false
|
let format: 'short' | 'full' | 'locale-string' = 'short'
|
||||||
let symbol: string
|
let symbol: string
|
||||||
|
|
||||||
if (typeof options === 'number') {
|
if (typeof options === 'number') {
|
||||||
seconds = options
|
seconds = options
|
||||||
} else {
|
} else {
|
||||||
seconds = options.seconds
|
seconds = options.seconds
|
||||||
fullFormat = options.fullFormat ?? false
|
format = options.format ?? 'short'
|
||||||
symbol = options.symbol
|
symbol = options.symbol
|
||||||
}
|
}
|
||||||
|
|
||||||
let time = ''
|
let time = ''
|
||||||
|
|
||||||
if (seconds === 0 && !fullFormat) return '0s'
|
if (seconds === 0 && format !== 'full') return '0s'
|
||||||
|
|
||||||
|
const formatNumber = (value: number) => {
|
||||||
|
if (format === 'locale-string') return value.toLocaleString()
|
||||||
|
|
||||||
|
return value
|
||||||
|
}
|
||||||
|
|
||||||
const hourSymbol = (symbol || 'h')
|
const hourSymbol = (symbol || 'h')
|
||||||
const minuteSymbol = (symbol || 'm')
|
const minuteSymbol = (symbol || 'm')
|
||||||
const secondsSymbol = fullFormat ? '' : 's'
|
const secondsSymbol = format === 'full' ? '' : 's'
|
||||||
|
|
||||||
const hours = Math.floor(seconds / 3600)
|
const hours = Math.floor(seconds / 3600)
|
||||||
if (hours >= 1 && hours < 10 && fullFormat) time = '0' + hours + hourSymbol
|
if (hours >= 1 && hours < 10 && format === 'full') time = '0' + hours + hourSymbol
|
||||||
else if (hours >= 1) time = hours + hourSymbol
|
else if (hours >= 1) time = formatNumber(hours) + hourSymbol
|
||||||
else if (fullFormat) time = '00' + hourSymbol
|
else if (format === 'full') time = '00' + hourSymbol
|
||||||
|
|
||||||
seconds %= 3600
|
seconds %= 3600
|
||||||
const minutes = Math.floor(seconds / 60)
|
const minutes = Math.floor(seconds / 60)
|
||||||
if (minutes >= 1 && minutes < 10 && fullFormat) time += '0' + minutes + minuteSymbol
|
if (minutes >= 1 && minutes < 10 && format === 'full') time += '0' + minutes + minuteSymbol
|
||||||
else if (minutes >= 1) time += minutes + minuteSymbol
|
else if (minutes >= 1) time += formatNumber(minutes) + minuteSymbol
|
||||||
else if (fullFormat) time += '00' + minuteSymbol
|
else if (format === 'full') time += '00' + minuteSymbol
|
||||||
|
|
||||||
seconds %= 60
|
seconds %= 60
|
||||||
if (seconds >= 1 && seconds < 10 && fullFormat) time += '0' + seconds + secondsSymbol
|
if (seconds >= 1 && seconds < 10 && format === 'full') time += '0' + seconds + secondsSymbol
|
||||||
else if (seconds >= 1) time += seconds + secondsSymbol
|
else if (seconds >= 1) time += formatNumber(seconds) + secondsSymbol
|
||||||
else if (fullFormat) time += '00'
|
else if (format === 'full') time += '00'
|
||||||
|
|
||||||
return time
|
return time
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------
|
||||||
|
|
||||||
export {
|
export {
|
||||||
|
|
Loading…
Reference in New Issue