From ee6108ccecfad58135e8d0db154a41a8e52e2bda Mon Sep 17 00:00:00 2001 From: softsimon Date: Sun, 19 Jul 2020 15:28:27 +0700 Subject: [PATCH] Display tx data on bisq transaction page. --- .../bisq-transaction.component.html | 30 +++++++++++++++--- .../bisq-transaction.component.ts | 31 +++++++++++++------ .../tx-features/tx-features.component.ts | 3 ++ 3 files changed, 50 insertions(+), 14 deletions(-) diff --git a/frontend/src/app/bisq/bisq-transaction/bisq-transaction.component.html b/frontend/src/app/bisq/bisq-transaction/bisq-transaction.component.html index f9def7206..f8d0c3ed5 100644 --- a/frontend/src/app/bisq/bisq-transaction/bisq-transaction.component.html +++ b/frontend/src/app/bisq/bisq-transaction/bisq-transaction.component.html @@ -27,17 +27,37 @@ ( ago) + + Features + + + + + + +
- - - + + + + + + + + + +
Burnt - {{ bisqTx.burntFee / 100 | number: '1.2-2' }} BSQ () -
Burnt + {{ bisqTx.burntFee / 100 | number: '1.2-2' }} BSQ () +
Fee per vByte + {{ tx.fee / (tx.weight / 4) | number : '1.1-1' }} sat/vB +   + +
diff --git a/frontend/src/app/bisq/bisq-transaction/bisq-transaction.component.ts b/frontend/src/app/bisq/bisq-transaction/bisq-transaction.component.ts index f758aa2f4..6da3c369f 100644 --- a/frontend/src/app/bisq/bisq-transaction/bisq-transaction.component.ts +++ b/frontend/src/app/bisq/bisq-transaction/bisq-transaction.component.ts @@ -4,7 +4,7 @@ import { BisqTransaction } from 'src/app/bisq/bisq.interfaces'; import { switchMap, map, catchError } from 'rxjs/operators'; import { of, Observable, Subscription } from 'rxjs'; import { StateService } from 'src/app/services/state.service'; -import { Block } from 'src/app/interfaces/electrs.interface'; +import { Block, Transaction } from 'src/app/interfaces/electrs.interface'; import { BisqApiService } from '../bisq-api.service'; import { SeoService } from 'src/app/services/seo.service'; import { ElectrsApiService } from 'src/app/services/electrs-api.service'; @@ -17,10 +17,12 @@ import { HttpErrorResponse } from '@angular/common/http'; }) export class BisqTransactionComponent implements OnInit, OnDestroy { bisqTx: BisqTransaction; + tx: Transaction; latestBlock$: Observable; txId: string; price: number; isLoading = true; + isLoadingTx = true; error = null; subscription: Subscription; @@ -37,6 +39,7 @@ export class BisqTransactionComponent implements OnInit, OnDestroy { this.subscription = this.route.paramMap.pipe( switchMap((params: ParamMap) => { this.isLoading = true; + this.isLoadingTx = true; this.error = null; document.body.scrollTo(0, 0); this.txId = params.get('id') || ''; @@ -71,21 +74,31 @@ export class BisqTransactionComponent implements OnInit, OnDestroy { return of(null); }) ); - }) + }), + switchMap((tx) => { + if (!tx) { + return of(null); + } + + if (tx.version) { + this.router.navigate(['/tx/', this.txId], { state: { data: tx, bsqTx: true }}); + return of(null); + } + + this.bisqTx = tx; + this.isLoading = false; + + return this.electrsApiService.getTransaction$(this.txId); + }), ) .subscribe((tx) => { - this.isLoading = false; + this.isLoadingTx = false; if (!tx) { return; } - if (tx.version) { - this.router.navigate(['/tx/', this.txId], { state: { data: tx, bsqTx: true }}); - return; - } - - this.bisqTx = tx; + this.tx = tx; }, (error) => { this.error = error; diff --git a/frontend/src/app/components/tx-features/tx-features.component.ts b/frontend/src/app/components/tx-features/tx-features.component.ts index 0c3711499..4136907ee 100644 --- a/frontend/src/app/components/tx-features/tx-features.component.ts +++ b/frontend/src/app/components/tx-features/tx-features.component.ts @@ -21,6 +21,9 @@ export class TxFeaturesComponent implements OnChanges { constructor() { } ngOnChanges() { + if (!this.tx) { + return; + } this.segwitGains = calcSegwitFeeGains(this.tx); this.isRbfTransaction = this.tx.vin.some((v) => v.sequence < 0xfffffffe); }