| 
									
										
										
										
											2025-04-03 22:48:54 +08:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Formats a number with comma separators. | 
					
						
							|  |  |  |  * @example formatNumber(1234567) will return '1,234,567' | 
					
						
							|  |  |  |  * @example formatNumber(1234567.89) will return '1,234,567.89' | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | export const formatNumber = (num: number | string) => { | 
					
						
							| 
									
										
										
										
											2023-08-14 12:46:28 +08:00
										 |  |  |   if (!num) | 
					
						
							|  |  |  |     return num | 
					
						
							|  |  |  |   const parts = num.toString().split('.') | 
					
						
							|  |  |  |   parts[0] = parts[0].replace(/\B(?=(\d{3})+(?!\d))/g, ',') | 
					
						
							|  |  |  |   return parts.join('.') | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-03 22:48:54 +08:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Format file size into standard string format. | 
					
						
							|  |  |  |  * @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 | 
					
						
							| 
									
										
										
										
											2023-08-14 12:46:28 +08:00
										 |  |  |   const units = ['', 'K', 'M', 'G', 'T', 'P'] | 
					
						
							|  |  |  |   let index = 0 | 
					
						
							| 
									
										
										
										
											2025-04-03 22:48:54 +08:00
										 |  |  |   while (fileSize >= 1024 && index < units.length) { | 
					
						
							|  |  |  |     fileSize = fileSize / 1024 | 
					
						
							| 
									
										
										
										
											2023-08-14 12:46:28 +08:00
										 |  |  |     index++ | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2025-04-03 22:48:54 +08:00
										 |  |  |   return `${fileSize.toFixed(2)}${units[index]}B` | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-03 22:48:54 +08:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Format time into standard string format. | 
					
						
							|  |  |  |  * @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 | 
					
						
							| 
									
										
										
										
											2023-08-14 12:46:28 +08:00
										 |  |  |   const units = ['sec', 'min', 'h'] | 
					
						
							|  |  |  |   let index = 0 | 
					
						
							| 
									
										
										
										
											2025-04-03 22:48:54 +08:00
										 |  |  |   while (seconds >= 60 && index < units.length) { | 
					
						
							|  |  |  |     seconds = seconds / 60 | 
					
						
							| 
									
										
										
										
											2023-08-14 12:46:28 +08:00
										 |  |  |     index++ | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2025-04-03 22:48:54 +08:00
										 |  |  |   return `${seconds.toFixed(2)} ${units[index]}` | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2025-02-17 17:05:13 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | export const downloadFile = ({ data, fileName }: { data: Blob; fileName: string }) => { | 
					
						
							|  |  |  |   const url = window.URL.createObjectURL(data) | 
					
						
							|  |  |  |   const a = document.createElement('a') | 
					
						
							|  |  |  |   a.href = url | 
					
						
							|  |  |  |   a.download = fileName | 
					
						
							|  |  |  |   document.body.appendChild(a) | 
					
						
							|  |  |  |   a.click() | 
					
						
							|  |  |  |   a.remove() | 
					
						
							|  |  |  |   window.URL.revokeObjectURL(url) | 
					
						
							|  |  |  | } |