mempool/frontend/src/app/components/fees-box/fees-box.component.ts

53 lines
1.5 KiB
TypeScript
Raw Normal View History

import { Component, OnInit, ChangeDetectionStrategy } from '@angular/core';
import { StateService } from 'src/app/services/state.service';
2020-07-29 10:20:23 +02:00
import { map, filter } from 'rxjs/operators';
import { Observable } from 'rxjs';
interface FeeEstimations {
fastestFee: number;
halfHourFee: number;
hourFee: number;
}
@Component({
selector: 'app-fees-box',
templateUrl: './fees-box.component.html',
styleUrls: ['./fees-box.component.scss'],
changeDetection: ChangeDetectionStrategy.OnPush,
})
export class FeesBoxComponent implements OnInit {
feeEstimations$: Observable<FeeEstimations>;
2020-07-30 08:13:22 +02:00
isLoadingWebSocket$: Observable<boolean>;
constructor(
private stateService: StateService,
) { }
ngOnInit(): void {
const defaultFee = this.stateService.network === 'liquid' ? 0.1 : 1;
2020-07-30 08:13:22 +02:00
this.isLoadingWebSocket$ = this.stateService.isLoadingWebSocket$;
this.feeEstimations$ = this.stateService.mempoolBlocks$
.pipe(
2020-07-29 10:20:23 +02:00
filter((blocks) => !!blocks.length),
map((pBlocks) => {
let firstMedianFee = Math.ceil(pBlocks[0].medianFee);
if (pBlocks.length === 1 && pBlocks[0].blockVSize <= 500000) {
firstMedianFee = defaultFee;
}
const secondMedianFee = pBlocks[1] ? Math.ceil(pBlocks[1].medianFee) : defaultFee;
const thirdMedianFee = pBlocks[2] ? Math.ceil(pBlocks[2].medianFee) : defaultFee;
return {
'fastestFee': firstMedianFee,
'halfHourFee': secondMedianFee,
'hourFee': thirdMedianFee,
};
})
);
}
}