doc: add JSDoc to file format.ts (#17426)

This commit is contained in:
yusheng chen 2025-04-03 22:48:54 +08:00 committed by GitHub
parent dcb8939c7f
commit 296e2ef90f
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -1,8 +1,8 @@
/* /**
* Formats a number with comma separators. * Formats a number with comma separators.
formatNumber(1234567) will return '1,234,567' * @example formatNumber(1234567) will return '1,234,567'
formatNumber(1234567.89) will return '1,234,567.89' * @example formatNumber(1234567.89) will return '1,234,567.89'
*/ */
export const formatNumber = (num: number | string) => { export const formatNumber = (num: number | string) => {
if (!num) if (!num)
return num return num
@ -11,28 +11,39 @@ export const formatNumber = (num: number | string) => {
return parts.join('.') return parts.join('.')
} }
export const formatFileSize = (num: number) => { /**
if (!num) * Format file size into standard string format.
return num * @param fileSize file size (Byte)
* @example formatFileSize(1024) will return '1.00KB'
* @example formatFileSize(1024 * 1024) will return '1.00MB'
*/
export const formatFileSize = (fileSize: number) => {
if (!fileSize)
return fileSize
const units = ['', 'K', 'M', 'G', 'T', 'P'] const units = ['', 'K', 'M', 'G', 'T', 'P']
let index = 0 let index = 0
while (num >= 1024 && index < units.length) { while (fileSize >= 1024 && index < units.length) {
num = num / 1024 fileSize = fileSize / 1024
index++ index++
} }
return `${num.toFixed(2)}${units[index]}B` return `${fileSize.toFixed(2)}${units[index]}B`
} }
export const formatTime = (num: number) => { /**
if (!num) * Format time into standard string format.
return num * @example formatTime(60) will return '1.00 min'
* @example formatTime(60 * 60) will return '1.00 h'
*/
export const formatTime = (seconds: number) => {
if (!seconds)
return seconds
const units = ['sec', 'min', 'h'] const units = ['sec', 'min', 'h']
let index = 0 let index = 0
while (num >= 60 && index < units.length) { while (seconds >= 60 && index < units.length) {
num = num / 60 seconds = seconds / 60
index++ index++
} }
return `${num.toFixed(2)} ${units[index]}` return `${seconds.toFixed(2)} ${units[index]}`
} }
export const downloadFile = ({ data, fileName }: { data: Blob; fileName: string }) => { export const downloadFile = ({ data, fileName }: { data: Blob; fileName: string }) => {