import { Component, ChangeDetectionStrategy, OnChanges, Input, OnInit, ChangeDetectorRef, OnDestroy } from '@angular/core'; import { Transaction, Block } from 'src/app/interfaces/electrs.interface'; import { StateService } from 'src/app/services/state.service'; import { Subscription } from 'rxjs'; @Component({ selector: 'app-tx-fee-rating', templateUrl: './tx-fee-rating.component.html', styleUrls: ['./tx-fee-rating.component.scss'], changeDetection: ChangeDetectionStrategy.OnPush, }) export class TxFeeRatingComponent implements OnInit, OnChanges, OnDestroy { @Input() tx: Transaction; blocksSubscription: Subscription; medianFeeNeeded: number; overpaidTimes: number; feeRating: number; blocks: Block[] = []; constructor( private stateService: StateService, private cd: ChangeDetectorRef, ) { } ngOnInit() { this.blocksSubscription = this.stateService.blocks$.subscribe(([block]) => { this.blocks.push(block); if (this.tx.status.confirmed && this.tx.status.block_height === block.height && block.medianFee > 0) { this.calculateRatings(block); this.cd.markForCheck(); } }); } ngOnChanges() { this.feeRating = undefined; if (!this.tx.status.confirmed) { return; } const foundBlock = this.blocks.find((b) => b.height === this.tx.status.block_height); if (foundBlock && foundBlock.medianFee > 0) { this.calculateRatings(foundBlock); } } ngOnDestroy() { this.blocksSubscription.unsubscribe(); } calculateRatings(block: Block) { const feePervByte = this.tx.fee / (this.tx.weight / 4); this.medianFeeNeeded = block.medianFee; // Block not filled if (block.weight < 4000000 * 0.95) { this.medianFeeNeeded = 1; } this.overpaidTimes = Math.round(feePervByte / this.medianFeeNeeded); if (feePervByte <= this.medianFeeNeeded || this.overpaidTimes < 2) { this.feeRating = 1; } else { this.feeRating = 2; if (this.overpaidTimes > 10) { this.feeRating = 3; } } } }