PeerTube/client/src/app/shared/shared-main/angular/number-formatter.pipe.ts

39 lines
1.3 KiB
TypeScript
Raw Normal View History

import { formatNumber } from '@angular/common'
import { Inject, LOCALE_ID, Pipe, PipeTransform } from '@angular/core'
2017-12-01 14:46:22 +01:00
2020-08-11 16:50:00 +02:00
// Thanks: https://github.com/danrevah/ngx-pipes/blob/master/src/ng-pipes/pipes/math/bytes.ts
2017-12-01 14:46:22 +01:00
2017-12-04 11:17:08 +01:00
@Pipe({ name: 'myNumberFormatter' })
2017-12-01 14:46:22 +01:00
export class NumberFormatterPipe implements PipeTransform {
/**
* @param x number
* @param n number of decimals to get (defaults to 1, needs to be >= 1)
*/
static getDecimalForNumber (x: number, n = 1) {
const v = x.toString().split('.')
const f = v[1] || ''
2022-11-15 15:16:41 +01:00
if (f.length > n) return +f.substring(0, n)
return +f
}
2023-05-24 15:27:15 +02:00
private dictionary: { max: number, type: string }[] = [
{ max: 1000, type: '' },
{ max: 1000000, type: 'K' },
{ max: 1000000000, type: 'M' }
]
2022-04-05 14:03:52 +02:00
constructor (@Inject(LOCALE_ID) private localeId: string) {}
2017-12-01 14:46:22 +01:00
transform (value: number) {
const format = this.dictionary.find(d => value < d.max) || this.dictionary[this.dictionary.length - 1]
const calc = value / (format.max / 1000)
const integralPart = Math.floor(calc)
const decimalPart = NumberFormatterPipe.getDecimalForNumber(calc)
2017-12-01 14:46:22 +01:00
return integralPart < 10 && decimalPart > 0
? formatNumber(parseFloat(`${integralPart}.${decimalPart}`), this.localeId) + format.type
: `${integralPart}${format.type}`
2017-12-01 14:46:22 +01:00
}
}