Switch all direct sat/vb fields to new rate component
This commit is contained in:
		
							parent
							
								
									c29558db20
								
							
						
					
					
						commit
						013ad803d0
					
				| @ -66,7 +66,7 @@ | |||||||
|                 <tr> |                 <tr> | ||||||
|                   <td i18n="transaction.fee-per-vbyte|Transaction fee">Fee per vByte</td> |                   <td i18n="transaction.fee-per-vbyte|Transaction fee">Fee per vByte</td> | ||||||
|                   <td *ngIf="!isLoadingTx; else loadingTxFee"> |                   <td *ngIf="!isLoadingTx; else loadingTxFee"> | ||||||
|                     {{ tx.fee / (tx.weight / 4) | feeRounding }} <span class="symbol">sat/vB</span> |                     <app-fee-rate [fee]="tx.fee" [weight]="tx.weight"></app-fee-rate> | ||||||
|                       |                       | ||||||
|                     <app-tx-fee-rating [tx]="tx"></app-tx-fee-rating> |                     <app-tx-fee-rating [tx]="tx"></app-tx-fee-rating> | ||||||
|                   </td> |                   </td> | ||||||
|  | |||||||
| @ -25,13 +25,13 @@ | |||||||
|       <tr> |       <tr> | ||||||
|         <td class="td-width" i18n="transaction.fee-rate|Transaction fee rate">Fee rate</td> |         <td class="td-width" i18n="transaction.fee-rate|Transaction fee rate">Fee rate</td> | ||||||
|         <td> |         <td> | ||||||
|           {{ feeRate | feeRounding }} <span class="symbol" i18n="shared.sat-vbyte|sat/vB">sat/vB</span> |           <app-fee-rate [fee]="feeRate"></app-fee-rate> | ||||||
|         </td> |         </td> | ||||||
|       </tr> |       </tr> | ||||||
|       <tr *ngIf="effectiveRate && effectiveRate !== feeRate"> |       <tr *ngIf="effectiveRate && effectiveRate !== feeRate"> | ||||||
|         <td class="td-width" i18n="transaction.effective-fee-rate|Effective transaction fee rate">Effective fee rate</td> |         <td class="td-width" i18n="transaction.effective-fee-rate|Effective transaction fee rate">Effective fee rate</td> | ||||||
|         <td> |         <td> | ||||||
|           {{ effectiveRate | feeRounding }} <span class="symbol" i18n="shared.sat-vbyte|sat/vB">sat/vB</span> |           <app-fee-rate [fee]="effectiveRate"></app-fee-rate> | ||||||
|         </td> |         </td> | ||||||
|       </tr> |       </tr> | ||||||
|       <tr> |       <tr> | ||||||
|  | |||||||
| @ -34,7 +34,7 @@ | |||||||
|           </tr> |           </tr> | ||||||
|           <tr *ngIf="block?.extras?.medianFee != undefined"> |           <tr *ngIf="block?.extras?.medianFee != undefined"> | ||||||
|             <td class="td-width" i18n="block.median-fee">Median fee</td> |             <td class="td-width" i18n="block.median-fee">Median fee</td> | ||||||
|             <td>~{{ block?.extras?.medianFee | number:'1.0-0' }} <span class="symbol" i18n="shared.sat-vbyte|sat/vB">sat/vB</span></td> |             <td>~<app-fee-rate [fee]="block?.extras?.medianFee" rounding="1.0-0"></app-fee-rate></td> | ||||||
|           </tr> |           </tr> | ||||||
|           <ng-template [ngIf]="fees !== undefined"> |           <ng-template [ngIf]="fees !== undefined"> | ||||||
|             <tr> |             <tr> | ||||||
|  | |||||||
| @ -121,11 +121,11 @@ | |||||||
|     <ng-container *ngIf="!isLoadingBlock; else loadingRest"> |     <ng-container *ngIf="!isLoadingBlock; else loadingRest"> | ||||||
|       <tr *ngIf="network !== 'liquid' && network !== 'liquidtestnet'"> |       <tr *ngIf="network !== 'liquid' && network !== 'liquidtestnet'"> | ||||||
|         <td i18n="mempool-block.fee-span">Fee span</td> |         <td i18n="mempool-block.fee-span">Fee span</td> | ||||||
|         <td><span>{{ block?.extras?.minFee | number:'1.0-0' }} - {{ block?.extras?.maxFee | number:'1.0-0' }} <span class="symbol" i18n="shared.sat-vbyte|sat/vB">sat/vB</span></span></td> |         <td><app-fee-rate [fee]="block?.extras?.minFee" [showUnit]="false" rounding="1.0-0"></app-fee-rate> - <app-fee-rate [fee]="block?.extras?.maxFee" rounding="1.0-0"></app-fee-rate></td> | ||||||
|       </tr> |       </tr> | ||||||
|       <tr *ngIf="block?.extras?.medianFee != undefined"> |       <tr *ngIf="block?.extras?.medianFee != undefined"> | ||||||
|         <td class="td-width" i18n="block.median-fee">Median fee</td> |         <td class="td-width" i18n="block.median-fee">Median fee</td> | ||||||
|         <td>~{{ block?.extras?.medianFee | number:'1.0-0' }} <span class="symbol" i18n="shared.sat-vbyte|sat/vB">sat/vB</span> |         <td>~<app-fee-rate [fee]="block?.extras?.medianFee" rounding="1.0-0"></app-fee-rate> | ||||||
|           <span class="fiat"> |           <span class="fiat"> | ||||||
|             <app-fiat [blockConversion]="blockConversion" [value]="block?.extras?.medianFee * 140" digitsInfo="1.2-2" |             <app-fiat [blockConversion]="blockConversion" [value]="block?.extras?.medianFee * 140" digitsInfo="1.2-2" | ||||||
|               i18n-ngbTooltip="Transaction fee tooltip" ngbTooltip="Based on average native segwit transaction of 140 vBytes" |               i18n-ngbTooltip="Transaction fee tooltip" ngbTooltip="Based on average native segwit transaction of 140 vBytes" | ||||||
|  | |||||||
| @ -22,8 +22,7 @@ | |||||||
|         <div class="block-body"> |         <div class="block-body"> | ||||||
|           <ng-container *ngIf="!minimal"> |           <ng-container *ngIf="!minimal"> | ||||||
|             <div *ngIf="block?.extras; else emptyfees" [attr.data-cy]="'bitcoin-block-offset=' + offset + '-index-' + i + '-fees'" class="fees"> |             <div *ngIf="block?.extras; else emptyfees" [attr.data-cy]="'bitcoin-block-offset=' + offset + '-index-' + i + '-fees'" class="fees"> | ||||||
|               ~{{ block?.extras?.medianFee | number:feeRounding }} <ng-container |               ~<app-fee-rate [fee]="block?.extras?.medianFee" unitClass="" rounding="1.0-0"></app-fee-rate> | ||||||
|                 i18n="shared.sat-vbyte|sat/vB">sat/vB</ng-container> |  | ||||||
|             </div> |             </div> | ||||||
|             <ng-template #emptyfees> |             <ng-template #emptyfees> | ||||||
|               <div [attr.data-cy]="'bitcoin-block-offset=' + offset + '-index-' + i + '-fees'" class="fees"> |               <div [attr.data-cy]="'bitcoin-block-offset=' + offset + '-index-' + i + '-fees'" class="fees"> | ||||||
| @ -32,8 +31,9 @@ | |||||||
|             </ng-template> |             </ng-template> | ||||||
|             <div [attr.data-cy]="'bitcoin-block-' + offset + '-index-' + i + '-fee-span'" class="fee-span" |             <div [attr.data-cy]="'bitcoin-block-' + offset + '-index-' + i + '-fee-span'" class="fee-span" | ||||||
|               *ngIf="block?.extras?.minFee != null && block?.extras?.maxFee != null; else emptyfeespan"> |               *ngIf="block?.extras?.minFee != null && block?.extras?.maxFee != null; else emptyfeespan"> | ||||||
|               {{ block.extras.minFee | number:feeRounding }} - {{ block.extras.maxFee | number:feeRounding }} <ng-container |               <app-fee-rate [fee]="block?.extras?.minFee" [showUnit]="false" rounding="1.0-0" unitClass=""></app-fee-rate> | ||||||
|                 i18n="shared.sat-vbyte|sat/vB">sat/vB</ng-container> |               - | ||||||
|  |               <app-fee-rate [fee]="block?.extras?.maxFee" rounding="1.0-0" unitClass=""></app-fee-rate> | ||||||
|             </div> |             </div> | ||||||
|             <ng-template #emptyfeespan> |             <ng-template #emptyfeespan> | ||||||
|               <div [attr.data-cy]="'bitcoin-block-offset=' + offset + '-index-' + i + '-fees'" class="fee-span"> |               <div [attr.data-cy]="'bitcoin-block-offset=' + offset + '-index-' + i + '-fees'" class="fee-span"> | ||||||
|  | |||||||
| @ -45,7 +45,9 @@ | |||||||
|     </div> |     </div> | ||||||
|     <div class="stats top right"> |     <div class="stats top right"> | ||||||
|       <p class="label" i18n="clock.priority-rate|priority fee rate">priority rate</p> |       <p class="label" i18n="clock.priority-rate|priority fee rate">priority rate</p> | ||||||
|       <p *ngIf="recommendedFees$ | async as recommendedFees;" i18n="shared.sat-vbyte|sat/vB">{{ recommendedFees.fastestFee }} sat/vB</p> |       <p *ngIf="recommendedFees$ | async as recommendedFees;"> | ||||||
|  |         <app-fee-rate [fee]="recommendedFees.fastestFee" unitClass="" rounding="1.0-0"></app-fee-rate> | ||||||
|  |       </p> | ||||||
|     </div> |     </div> | ||||||
|     <div *ngIf="mode !== 'mempool' && blocks?.length" class="stats bottom left"> |     <div *ngIf="mode !== 'mempool' && blocks?.length" class="stats bottom left"> | ||||||
|       <p [innerHTML]="blocks[blockIndex].size | bytes: 2"></p> |       <p [innerHTML]="blocks[blockIndex].size | bytes: 2"></p> | ||||||
|  | |||||||
| @ -13,23 +13,23 @@ | |||||||
|   <div class="fee-estimation-container"> |   <div class="fee-estimation-container"> | ||||||
|     <div class="item"> |     <div class="item"> | ||||||
|       <div class="card-text"> |       <div class="card-text"> | ||||||
|         <div class="fee-text">{{ recommendedFees.economyFee }} <span i18n="shared.sat-vbyte|sat/vB">sat/vB</span></div> <span class="fiat"><app-fiat i18n-ngbTooltip="Transaction fee tooltip" ngbTooltip="Based on average native segwit transaction of 140 vBytes" placement="bottom" [value]="recommendedFees.economyFee * 140" ></app-fiat></span> |         <div class="fee-text"><app-fee-rate [fee]="recommendedFees.economyFee"  rounding="1.0-0"></app-fee-rate></div> <span class="fiat"><app-fiat i18n-ngbTooltip="Transaction fee tooltip" ngbTooltip="Based on average native segwit transaction of 140 vBytes" placement="bottom" [value]="recommendedFees.economyFee * 140" ></app-fiat></span> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|     <div class="band-separator"></div> |     <div class="band-separator"></div> | ||||||
|     <div class="item"> |     <div class="item"> | ||||||
|       <div class="card-text"> |       <div class="card-text"> | ||||||
|         <div class="fee-text">{{ recommendedFees.hourFee }} <span i18n="shared.sat-vbyte|sat/vB">sat/vB</span></div> <span class="fiat"><app-fiat i18n-ngbTooltip="Transaction fee tooltip" ngbTooltip="Based on average native segwit transaction of 140 vBytes" placement="bottom" [value]="recommendedFees.hourFee * 140" ></app-fiat></span> |         <div class="fee-text"><app-fee-rate [fee]="recommendedFees.hourFee"  rounding="1.0-0"></app-fee-rate></div> <span class="fiat"><app-fiat i18n-ngbTooltip="Transaction fee tooltip" ngbTooltip="Based on average native segwit transaction of 140 vBytes" placement="bottom" [value]="recommendedFees.hourFee * 140" ></app-fiat></span> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|     <div class="item"> |     <div class="item"> | ||||||
|       <div class="card-text"> |       <div class="card-text"> | ||||||
|         <div class="fee-text">{{ recommendedFees.halfHourFee }} <span i18n="shared.sat-vbyte|sat/vB">sat/vB</span></div> <span class="fiat"><app-fiat i18n-ngbTooltip="Transaction fee tooltip" ngbTooltip="Based on average native segwit transaction of 140 vBytes" placement="bottom" [value]="recommendedFees.halfHourFee * 140" ></app-fiat></span> |         <div class="fee-text"><app-fee-rate [fee]="recommendedFees.halfHourFee"  rounding="1.0-0"></app-fee-rate></div> <span class="fiat"><app-fiat i18n-ngbTooltip="Transaction fee tooltip" ngbTooltip="Based on average native segwit transaction of 140 vBytes" placement="bottom" [value]="recommendedFees.halfHourFee * 140" ></app-fiat></span> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|     <div class="item"> |     <div class="item"> | ||||||
|       <div class="card-text"> |       <div class="card-text"> | ||||||
|         <div class="fee-text">{{ recommendedFees.fastestFee }} <span i18n="shared.sat-vbyte|sat/vB">sat/vB</span></div> <span class="fiat"><app-fiat i18n-ngbTooltip="Transaction fee tooltip" ngbTooltip="Based on average native segwit transaction of 140 vBytes" placement="bottom" [value]="recommendedFees.fastestFee * 140" ></app-fiat></span> |         <div class="fee-text"><app-fee-rate [fee]="recommendedFees.fastestFee"  rounding="1.0-0"></app-fee-rate></div> <span class="fiat"><app-fiat i18n-ngbTooltip="Transaction fee tooltip" ngbTooltip="Based on average native segwit transaction of 140 vBytes" placement="bottom" [value]="recommendedFees.fastestFee * 140" ></app-fiat></span> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|   </div> |   </div> | ||||||
|  | |||||||
| @ -14,11 +14,15 @@ | |||||||
|           <tbody> |           <tbody> | ||||||
|             <tr> |             <tr> | ||||||
|               <td i18n="mempool-block.median-fee">Median fee</td> |               <td i18n="mempool-block.median-fee">Median fee</td> | ||||||
|               <td>~{{ mempoolBlock.medianFee | number:'1.0-0' }} <span class="symbol" i18n="shared.sat-vbyte|sat/vB">sat/vB</span> <span class="fiat"><app-fiat [value]="mempoolBlock.medianFee * 140" digitsInfo="1.2-2" i18n-ngbTooltip="Transaction fee tooltip" ngbTooltip="Based on average native segwit transaction of 140 vBytes" placement="bottom"></app-fiat></span></td> |               <td>~<app-fee-rate [fee]="mempoolBlock.medianFee" rounding="1.0-0"></app-fee-rate> <span class="fiat"><app-fiat [value]="mempoolBlock.medianFee * 140" digitsInfo="1.2-2" i18n-ngbTooltip="Transaction fee tooltip" ngbTooltip="Based on average native segwit transaction of 140 vBytes" placement="bottom"></app-fiat></span></td> | ||||||
|             </tr> |             </tr> | ||||||
|             <tr> |             <tr> | ||||||
|               <td i18n="mempool-block.fee-span">Fee span</td> |               <td i18n="mempool-block.fee-span">Fee span</td> | ||||||
|               <td><span class="yellow-color">{{ mempoolBlock.feeRange[0] | number:'1.0-0' }} - {{ mempoolBlock.feeRange[mempoolBlock.feeRange.length - 1] | number:'1.0-0' }} <span class="symbol" i18n="shared.sat-vbyte|sat/vB">sat/vB</span></span></td> |               <td><span class="yellow-color"> | ||||||
|  |                 <app-fee-rate [fee]="mempoolBlock.feeRange[0]" [showUnit]="false" rounding="1.0-0"></app-fee-rate> | ||||||
|  |                 - | ||||||
|  |                 <app-fee-rate [fee]="mempoolBlock.feeRange[mempoolBlock.feeRange.length - 1]" rounding="1.0-0"></app-fee-rate> | ||||||
|  |               </span></td> | ||||||
|             </tr> |             </tr> | ||||||
|             <tr> |             <tr> | ||||||
|               <td i18n="block.total-fees|Total fees in a block">Total fees</td> |               <td i18n="block.total-fees|Total fees in a block">Total fees</td> | ||||||
|  | |||||||
| @ -13,10 +13,12 @@ | |||||||
|           <div class="block-body"> |           <div class="block-body"> | ||||||
|             <ng-container *ngIf="!minimal"> |             <ng-container *ngIf="!minimal"> | ||||||
|               <div [attr.data-cy]="'mempool-block-' + i + '-fees'" class="fees"> |               <div [attr.data-cy]="'mempool-block-' + i + '-fees'" class="fees"> | ||||||
|                 ~{{ projectedBlock.medianFee | number:feeRounding }} <span i18n="shared.sat-vbyte|sat/vB">sat/vB</span> |                 ~<app-fee-rate [fee]="projectedBlock.medianFee" unitClass="" rounding="1.0-0"></app-fee-rate> | ||||||
|               </div> |               </div> | ||||||
|               <div [attr.data-cy]="'mempool-block-' + i + '-fee-span'" class="fee-span"> |               <div [attr.data-cy]="'mempool-block-' + i + '-fee-span'" class="fee-span"> | ||||||
|                 {{ projectedBlock.feeRange[0] | number:feeRounding }} - {{ projectedBlock.feeRange[projectedBlock.feeRange.length - 1] | number:feeRounding }} <span i18n="shared.sat-vbyte|sat/vB">sat/vB</span> |                 <app-fee-rate [fee]="projectedBlock.feeRange[0]" [showUnit]="false" rounding="1.0-0" unitClass=""></app-fee-rate> | ||||||
|  |                 - | ||||||
|  |                 <app-fee-rate [fee]="projectedBlock.feeRange[projectedBlock.feeRange.length - 1]" rounding="1.0-0" unitClass=""></app-fee-rate> | ||||||
|               </div> |               </div> | ||||||
|               <div *ngIf="showMiningInfo" class="block-size"> |               <div *ngIf="showMiningInfo" class="block-size"> | ||||||
|                 <app-amount [attr.data-cy]="'mempool-block-' + i + '-total-fees'" [satoshis]="projectedBlock.totalFees" digitsInfo="1.2-3" [noFiat]="true"></app-amount> |                 <app-amount [attr.data-cy]="'mempool-block-' + i + '-total-fees'" [satoshis]="projectedBlock.totalFees" digitsInfo="1.2-3" [noFiat]="true"></app-amount> | ||||||
|  | |||||||
| @ -31,7 +31,7 @@ | |||||||
|               > |               > | ||||||
|                 <div class="shape"></div> |                 <div class="shape"></div> | ||||||
|               </a> |               </a> | ||||||
|               <span class="fee-rate">{{ cell.replacement.tx.fee / (cell.replacement.tx.vsize) | feeRounding }} <span class="symbol" i18n="shared.sat-vbyte|sat/vB">sat/vB</span></span> |               <span class="fee-rate"><app-fee-rate [fee]="cell.replacement.tx.fee" [weight]="cell.replacement.tx.vsize * 4"></app-fee-rate></span> | ||||||
|             </div> |             </div> | ||||||
|           </ng-container> |           </ng-container> | ||||||
|           <ng-template #nonNode> |           <ng-template #nonNode> | ||||||
|  | |||||||
| @ -33,7 +33,7 @@ | |||||||
|         <span [innerHTML]="'‎' + (tx.weight | wuBytes: 2)"></span> |         <span [innerHTML]="'‎' + (tx.weight | wuBytes: 2)"></span> | ||||||
|       </p> |       </p> | ||||||
|       <p class="field" *ngIf="!isCoinbase(tx)"> |       <p class="field" *ngIf="!isCoinbase(tx)"> | ||||||
|         {{ tx.feePerVsize | feeRounding }} <span class="symbol" i18n="shared.sat-vbyte|sat/vB">sat/vB</span> |         <app-fee-rate [fee]="tx.feePerVsize"></app-fee-rate> | ||||||
|       </p> |       </p> | ||||||
|     </div> |     </div> | ||||||
|     <div class="overlaid"> |     <div class="overlaid"> | ||||||
|  | |||||||
| @ -150,7 +150,7 @@ | |||||||
|                   <app-truncate [text]="cpfpTx.txid" [link]="['/tx' | relativeUrl, cpfpTx.txid]"></app-truncate> |                   <app-truncate [text]="cpfpTx.txid" [link]="['/tx' | relativeUrl, cpfpTx.txid]"></app-truncate> | ||||||
|                 </td> |                 </td> | ||||||
|                 <td class="d-none d-lg-table-cell" [innerHTML]="cpfpTx.weight / 4 | vbytes: 2"></td> |                 <td class="d-none d-lg-table-cell" [innerHTML]="cpfpTx.weight / 4 | vbytes: 2"></td> | ||||||
|                 <td>{{ cpfpTx.fee / (cpfpTx.weight / 4) | feeRounding }} <span class="symbol" i18n="shared.sat-vbyte|sat/vB">sat/vB</span></td> |                 <td><app-fee-rate [fee]="cpfpTx.fee" [weight]="cpfpTx.weight"></app-fee-rate></td> | ||||||
|                 <td class="d-none d-lg-table-cell"><fa-icon  *ngIf="roundToOneDecimal(cpfpTx) > roundToOneDecimal(tx)"  class="arrow-green" [icon]="['fas', 'angle-double-up']" [fixedWidth]="true"></fa-icon></td> |                 <td class="d-none d-lg-table-cell"><fa-icon  *ngIf="roundToOneDecimal(cpfpTx) > roundToOneDecimal(tx)"  class="arrow-green" [icon]="['fas', 'angle-double-up']" [fixedWidth]="true"></fa-icon></td> | ||||||
|               </tr> |               </tr> | ||||||
|             </ng-template> |             </ng-template> | ||||||
| @ -161,7 +161,7 @@ | |||||||
|                   <app-truncate [text]="cpfpInfo.bestDescendant.txid" [link]="['/tx' | relativeUrl, cpfpInfo.bestDescendant.txid]"></app-truncate> |                   <app-truncate [text]="cpfpInfo.bestDescendant.txid" [link]="['/tx' | relativeUrl, cpfpInfo.bestDescendant.txid]"></app-truncate> | ||||||
|                 </td> |                 </td> | ||||||
|                 <td class="d-none d-lg-table-cell" [innerHTML]="cpfpInfo.bestDescendant.weight / 4 | vbytes: 2"></td> |                 <td class="d-none d-lg-table-cell" [innerHTML]="cpfpInfo.bestDescendant.weight / 4 | vbytes: 2"></td> | ||||||
|                 <td>{{ cpfpInfo.bestDescendant.fee / (cpfpInfo.bestDescendant.weight / 4) | feeRounding }} <span class="symbol" i18n="shared.sat-vbyte|sat/vB">sat/vB</span></td> |                 <td><app-fee-rate [fee]="cpfpInfo.bestDescendant.fee" [weight]="cpfpInfo.bestDescendant.weight"></app-fee-rate></td> | ||||||
|                 <td class="d-none d-lg-table-cell"><fa-icon class="arrow-green" [icon]="['fas', 'angle-double-up']" [fixedWidth]="true"></fa-icon></td> |                 <td class="d-none d-lg-table-cell"><fa-icon class="arrow-green" [icon]="['fas', 'angle-double-up']" [fixedWidth]="true"></fa-icon></td> | ||||||
|               </tr> |               </tr> | ||||||
|             </ng-template> |             </ng-template> | ||||||
| @ -172,7 +172,7 @@ | |||||||
|                   <app-truncate [text]="cpfpTx.txid" [link]="['/tx' | relativeUrl, cpfpTx.txid]"></app-truncate> |                   <app-truncate [text]="cpfpTx.txid" [link]="['/tx' | relativeUrl, cpfpTx.txid]"></app-truncate> | ||||||
|                 </td> |                 </td> | ||||||
|                 <td class="d-none d-lg-table-cell" [innerHTML]="cpfpTx.weight / 4 | vbytes: 2"></td> |                 <td class="d-none d-lg-table-cell" [innerHTML]="cpfpTx.weight / 4 | vbytes: 2"></td> | ||||||
|                 <td>{{ cpfpTx.fee / (cpfpTx.weight / 4) | feeRounding }} <span class="symbol" i18n="shared.sat-vbyte|sat/vB">sat/vB</span></td> |                 <td><app-fee-rate [fee]="cpfpTx.fee" [weight]="cpfpTx.weight"></app-fee-rate></td> | ||||||
|                 <td class="d-none d-lg-table-cell"><fa-icon *ngIf="roundToOneDecimal(cpfpTx) < roundToOneDecimal(tx)" class="arrow-red" [icon]="['fas', 'angle-double-down']" [fixedWidth]="true"></fa-icon></td> |                 <td class="d-none d-lg-table-cell"><fa-icon *ngIf="roundToOneDecimal(cpfpTx) < roundToOneDecimal(tx)" class="arrow-red" [icon]="['fas', 'angle-double-down']" [fixedWidth]="true"></fa-icon></td> | ||||||
|               </tr> |               </tr> | ||||||
|             </ng-template> |             </ng-template> | ||||||
| @ -475,7 +475,7 @@ | |||||||
|       <tr> |       <tr> | ||||||
|         <td i18n="transaction.fee-rate|Transaction fee rate">Fee rate</td> |         <td i18n="transaction.fee-rate|Transaction fee rate">Fee rate</td> | ||||||
|         <td> |         <td> | ||||||
|           {{ tx.feePerVsize | feeRounding }} <span class="symbol" i18n="shared.sat-vbyte|sat/vB">sat/vB</span> |           <app-fee-rate [fee]="tx.feePerVsize"></app-fee-rate> | ||||||
|           <ng-template [ngIf]="tx?.status?.confirmed"> |           <ng-template [ngIf]="tx?.status?.confirmed"> | ||||||
|               |               | ||||||
|             <app-tx-fee-rating *ngIf="tx.fee && !hasEffectiveFeeRate" [tx]="tx"></app-tx-fee-rating> |             <app-tx-fee-rating *ngIf="tx.fee && !hasEffectiveFeeRate" [tx]="tx"></app-tx-fee-rating> | ||||||
| @ -486,7 +486,7 @@ | |||||||
|         <td i18n="transaction.effective-fee-rate|Effective transaction fee rate">Effective fee rate</td> |         <td i18n="transaction.effective-fee-rate|Effective transaction fee rate">Effective fee rate</td> | ||||||
|         <td> |         <td> | ||||||
|           <div class="effective-fee-container"> |           <div class="effective-fee-container"> | ||||||
|             {{ tx.effectiveFeePerVsize | feeRounding }} <span class="symbol" i18n="shared.sat-vbyte|sat/vB">sat/vB</span> |             <app-fee-rate [fee]="tx.effectiveFeePerVsize"></app-fee-rate> | ||||||
|             <ng-template [ngIf]="tx?.status?.confirmed"> |             <ng-template [ngIf]="tx?.status?.confirmed"> | ||||||
|               <app-tx-fee-rating class="ml-2 mr-2" *ngIf="tx.fee || tx.effectiveFeePerVsize" [tx]="tx"></app-tx-fee-rating> |               <app-tx-fee-rating class="ml-2 mr-2" *ngIf="tx.fee || tx.effectiveFeePerVsize" [tx]="tx"></app-tx-fee-rating> | ||||||
|             </ng-template> |             </ng-template> | ||||||
|  | |||||||
| @ -290,8 +290,8 @@ | |||||||
| 
 | 
 | ||||||
|     <div class="summary"> |     <div class="summary"> | ||||||
|       <div class="float-left mt-2-5" *ngIf="!transactionPage && !tx.vin[0].is_coinbase && tx.fee !== -1"> |       <div class="float-left mt-2-5" *ngIf="!transactionPage && !tx.vin[0].is_coinbase && tx.fee !== -1"> | ||||||
|         {{ tx.fee / (tx.weight / 4) | feeRounding }} <span class="symbol" i18n="shared.sat-vbyte|sat/vB">sat/vB</span> <span |         <app-fee-rate [fee]="tx.fee" [weight]="tx.weight"></app-fee-rate> | ||||||
|           class="d-none d-sm-inline-block"> – {{ tx.fee | number }} <span class="symbol" |         <span class="d-none d-sm-inline-block"> – {{ tx.fee | number }} <span class="symbol" | ||||||
|             i18n="shared.sat|sat">sat</span> <span class="fiat"><app-fiat [blockConversion]="tx.price" [value]="tx.fee"></app-fiat></span></span> |             i18n="shared.sat|sat">sat</span> <span class="fiat"><app-fiat [blockConversion]="tx.price" [value]="tx.fee"></app-fiat></span></span> | ||||||
|       </div> |       </div> | ||||||
|       <div class="float-left mt-2-5 grey-info-text" *ngIf="tx.fee === -1" i18n="transactions-list.load-to-reveal-fee-info">Show more inputs to reveal fee data</div> |       <div class="float-left mt-2-5 grey-info-text" *ngIf="tx.fee === -1" i18n="transactions-list.load-to-reveal-fee-info">Show more inputs to reveal fee data</div> | ||||||
|  | |||||||
| @ -132,7 +132,7 @@ | |||||||
|                 </td> |                 </td> | ||||||
|                 <td class="table-cell-satoshis"><app-amount *ngIf="(network$ | async) !== 'liquid' && (network$ | async) !== 'liquidtestnet'; else liquidAmount" [satoshis]="transaction.value" digitsInfo="1.2-4" [noFiat]="true"></app-amount><ng-template #liquidAmount i18n="shared.confidential">Confidential</ng-template></td> |                 <td class="table-cell-satoshis"><app-amount *ngIf="(network$ | async) !== 'liquid' && (network$ | async) !== 'liquidtestnet'; else liquidAmount" [satoshis]="transaction.value" digitsInfo="1.2-4" [noFiat]="true"></app-amount><ng-template #liquidAmount i18n="shared.confidential">Confidential</ng-template></td> | ||||||
|                 <td class="table-cell-fiat" *ngIf="(network$ | async) === ''" ><app-fiat [value]="transaction.value" digitsInfo="1.0-0"></app-fiat></td> |                 <td class="table-cell-fiat" *ngIf="(network$ | async) === ''" ><app-fiat [value]="transaction.value" digitsInfo="1.0-0"></app-fiat></td> | ||||||
|                 <td class="table-cell-fees">{{ transaction.fee / transaction.vsize | feeRounding }} <span class="symbol" i18n="shared.sat-vbyte|sat/vB">sat/vB</span></td> |                 <td class="table-cell-fees"><app-fee-rate [fee]="transaction.fee" [weight]="transaction.vsize * 4"></app-fee-rate></td> | ||||||
|               </tr> |               </tr> | ||||||
|             </tbody> |             </tbody> | ||||||
|           </table> |           </table> | ||||||
| @ -188,7 +188,7 @@ | |||||||
|       <h5 *ngIf="!mempoolInfoData.value || mempoolInfoData.value.memPoolInfo.mempoolminfee === 0.00001 || (stateService.env.BASE_MODULE === 'liquid' && mempoolInfoData.value.memPoolInfo.mempoolminfee === 0.000001) else purgingText" class="card-title" i18n="dashboard.minimum-fee|Minimum mempool fee">Minimum fee</h5> |       <h5 *ngIf="!mempoolInfoData.value || mempoolInfoData.value.memPoolInfo.mempoolminfee === 0.00001 || (stateService.env.BASE_MODULE === 'liquid' && mempoolInfoData.value.memPoolInfo.mempoolminfee === 0.000001) else purgingText" class="card-title" i18n="dashboard.minimum-fee|Minimum mempool fee">Minimum fee</h5> | ||||||
|       <ng-template #purgingText><h5 class="card-title" i18n="dashboard.purging|Purgin below fee">Purging</h5></ng-template> |       <ng-template #purgingText><h5 class="card-title" i18n="dashboard.purging|Purgin below fee">Purging</h5></ng-template> | ||||||
|       <p class="card-text" *ngIf="(isLoadingWebSocket$ | async) === false && mempoolInfoData.value; else loading"> |       <p class="card-text" *ngIf="(isLoadingWebSocket$ | async) === false && mempoolInfoData.value; else loading"> | ||||||
|         <ng-template [ngIf]="mempoolInfoData.value.memPoolInfo.mempoolminfee > 0.00001">< </ng-template>{{ mempoolInfoData.value.memPoolInfo.mempoolminfee * 100000 | feeRounding }} <span><ng-container i18n="shared.sat-vbyte|sat/vB">sat/vB</ng-container></span> |         <ng-template [ngIf]="mempoolInfoData.value.memPoolInfo.mempoolminfee > 0.00001">< </ng-template><app-fee-rate [fee]="mempoolInfoData.value.memPoolInfo.mempoolminfee * 100000"></app-fee-rate> | ||||||
|       </p> |       </p> | ||||||
|     </div> |     </div> | ||||||
|     <div class="item"> |     <div class="item"> | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| <ng-container *ngIf="rateUnits$ | async as units"> | <ng-container *ngIf="rateUnits$ | async as units"> | ||||||
|   <ng-container *ngIf="units !== 'wu'">{{ fee / (weight / 4) | feeRounding:rounding }} <span *ngIf="showUnit" [class]="unitClass">sat/vB</span></ng-container> |   <ng-container *ngIf="units !== 'wu'">{{ fee / (weight / 4) | feeRounding:rounding }} <span *ngIf="showUnit" [class]="unitClass" [style]="unitStyle">sat/vB</span></ng-container> | ||||||
|   <ng-container *ngIf="units === 'wu'">{{ fee / weight | feeRounding:rounding }} <span *ngIf="showUnit" [class]="unitClass">sat/WU</span></ng-container> |   <ng-container *ngIf="units === 'wu'">{{ fee / weight | feeRounding:rounding }} <span *ngIf="showUnit" [class]="unitClass" [style]="unitStyle">sat/WU</span></ng-container> | ||||||
| </ng-container> | </ng-container> | ||||||
| @ -13,6 +13,7 @@ export class FeeRateComponent implements OnInit { | |||||||
|   @Input() rounding: string = null; |   @Input() rounding: string = null; | ||||||
|   @Input() showUnit: boolean = true; |   @Input() showUnit: boolean = true; | ||||||
|   @Input() unitClass: string = 'symbol'; |   @Input() unitClass: string = 'symbol'; | ||||||
|  |   @Input() unitStyle: any; | ||||||
| 
 | 
 | ||||||
|   rateUnits$: Observable<string>; |   rateUnits$: Observable<string>; | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user