139 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			139 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <div class="container-lg widget-container" [class.widget]="widget" [class.full-height]="!widget">
 | |
|   <h1 *ngIf="!widget" class="float-left" i18n="accelerator.accelerations">Accelerations</h1>
 | |
|   <div *ngIf="!widget && isLoading" class="spinner-border ml-3" role="status"></div>
 | |
| 
 | |
|   <div class="clearfix"></div>
 | |
| 
 | |
|   <div class="acceleration-list" *ngIf="{ accelerations: accelerationList$ | async } as state">
 | |
|     <table *ngIf="nonEmptyAccelerations; else noData" class="table table-borderless table-fixed">
 | |
|       <thead>
 | |
|         <th class="txid text-left" i18n="dashboard.latest-transactions.txid">TXID</th>
 | |
|         <ng-container *ngIf="pending">
 | |
|           <th class="fee-rate text-right" i18n="transaction.fee-rate|Transaction fee rate">Fee rate</th>
 | |
|           <th class="bid text-right" i18n="accelerator.bid">Bid</th>
 | |
|           <th class="time text-right" i18n="accelerator.requested">Requested</th>
 | |
|         </ng-container>
 | |
|         <ng-container *ngIf="!pending">
 | |
|           <th class="fee text-right" i18n="transaction.bid-boost|Bid Boost">Bid Boost</th>
 | |
|           <th class="block text-right" i18n="shared.block-title">Block</th>
 | |
|           <th class="pool text-right" i18n="mining.pool-name" *ngIf="!this.widget">Pool</th>
 | |
|           <th class="status text-right" i18n="transaction.status|Transaction Status">Status</th>
 | |
|           <th class="date text-right" i18n="accelerator.requested" *ngIf="!this.widget">Requested</th>
 | |
|         </ng-container>
 | |
|       </thead>
 | |
|       <tbody *ngIf="state.accelerations && nonEmptyAccelerations; else skeleton" [style]="isLoading ? 'opacity: 0.75' : ''">
 | |
|         <tr *ngFor="let acceleration of state.accelerations; let i= index;">
 | |
|           <td class="txid text-left">
 | |
|             <a [routerLink]="['/tx' | relativeUrl, acceleration.txid]">
 | |
|               <app-truncate [text]="acceleration.txid" [lastChars]="5"></app-truncate>
 | |
|             </a>
 | |
|           </td>
 | |
|           <ng-container *ngIf="pending">
 | |
|             <td class="fee-rate text-right">
 | |
|               <app-fee-rate [fee]="acceleration.effectiveFee" [weight]="acceleration.effectiveVsize * 4"></app-fee-rate>
 | |
|             </td>
 | |
|             <td class="bid text-right">
 | |
|               {{ (acceleration.feeDelta) | number }} <span class="symbol" i18n="shared.sats">sats</span>
 | |
|             </td>
 | |
|             <td class="time text-right">
 | |
|               <app-time kind="since" [time]="acceleration.added" [fastRender]="true" [showTooltip]="true"></app-time>
 | |
|             </td>
 | |
|           </ng-container>
 | |
|           <ng-container *ngIf="!pending">
 | |
|             <td *ngIf="acceleration.boost != null" class="fee text-right">
 | |
|               {{ acceleration.boost | number }} <span class="symbol" i18n="shared.sats">sats</span>
 | |
|             </td>
 | |
|             <td *ngIf="acceleration.boost == null" class="fee text-right">
 | |
|               ~
 | |
|             </td>
 | |
|             <td class="block text-right">
 | |
|               <a *ngIf="acceleration.blockHeight" [routerLink]="['/block' | relativeUrl, acceleration.blockHeight]">{{ acceleration.blockHeight }}</a>
 | |
|               <span *ngIf="!acceleration.blockHeight">~</span>
 | |
|             </td>
 | |
|             <td class="pool text-right" *ngIf="!this.widget">
 | |
|               @if (acceleration.minedByPoolUniqueId && pools[acceleration.minedByPoolUniqueId]) {
 | |
|                 <a placement="bottom" [routerLink]="['/mining/pool' | relativeUrl, pools[acceleration.minedByPoolUniqueId].slug]" class="badge" style="color: #FFF;padding:0;">
 | |
|                   <img class="pool-logo" [src]="'/resources/mining-pools/' + pools[acceleration.minedByPoolUniqueId].slug + '.svg'" onError="this.src = '/resources/mining-pools/default.svg'" [alt]="'Logo of ' + pools[acceleration.minedByPoolUniqueId].name + ' mining pool'">
 | |
|                   {{ pools[acceleration.minedByPoolUniqueId].name }}
 | |
|                 </a>
 | |
|               } @else {
 | |
|                 ~
 | |
|               }
 | |
|             </td>
 | |
|             <td class="status text-right">
 | |
|               <span *ngIf="acceleration.status === 'accelerating'" class="badge badge-warning" i18n="accelerator.pending">Pending</span>
 | |
|               <span *ngIf="acceleration.status.includes('completed') && acceleration.minedByPoolUniqueId && pools[acceleration.minedByPoolUniqueId]" class="badge badge-success"><ng-container i18n="accelerator.completed">Completed</ng-container><span *ngIf="acceleration.status === 'completed_provisional'"> ⌛</span></span>
 | |
|               <span *ngIf="acceleration.status.includes('completed') && (!acceleration.minedByPoolUniqueId || !pools[acceleration.minedByPoolUniqueId])" class="badge badge-success"><ng-container i18n="transaction.rbf.mined">Mined</ng-container><span *ngIf="acceleration.status === 'completed_provisional'"> ⌛</span></span>
 | |
|               <span *ngIf="acceleration.status.includes('failed')" class="badge badge-danger"><ng-container i18n="accelerator.canceled">Canceled</ng-container><span *ngIf="acceleration.status === 'failed_provisional'"> ⌛</span></span>
 | |
|             </td>
 | |
|             <td class="date text-right" *ngIf="!this.widget">
 | |
|               <app-time kind="since" [time]="acceleration.added" [fastRender]="true" [showTooltip]="true"></app-time>
 | |
|             </td>
 | |
|           </ng-container>
 | |
|         </tr>
 | |
|       </tbody>
 | |
|       <ng-template #skeleton>
 | |
|         @if (!pending) {
 | |
|           <tbody>
 | |
|             <tr *ngFor="let item of skeletonLines">
 | |
|               <td class="txid text-left">
 | |
|                 <span class="skeleton-loader" style="max-width: 200px"></span>
 | |
|               </td>
 | |
|               <td class="fee text-right">
 | |
|                 <span class="skeleton-loader" style="max-width: 100px"></span>
 | |
|               </td>
 | |
|               <td class="block text-right">
 | |
|                 <span class="skeleton-loader" style="max-width: 100px"></span>
 | |
|               </td>
 | |
|               <td class="pool text-right" *ngIf="!this.widget">
 | |
|                 <span class="skeleton-loader" style="max-width: 100px"></span>
 | |
|               </td>
 | |
|               <td class="status text-right">
 | |
|                 <span class="skeleton-loader" style="max-width: 100px"></span>
 | |
|               </td>
 | |
|               <td class="date text-right" *ngIf="!this.widget">
 | |
|                 <span class="skeleton-loader" style="max-width: 100px"></span>
 | |
|               </td>
 | |
|             </tr>
 | |
|           </tbody>
 | |
|         } @else {
 | |
|           <tbody>
 | |
|             <tr *ngFor="let item of skeletonLines">
 | |
|               <td class="txid text-left">
 | |
|                 <span class="skeleton-loader" style="max-width: 100px"></span>
 | |
|               </td>
 | |
|               <td class="fee-rate text-right">
 | |
|                 <span class="skeleton-loader" style="max-width: 100px"></span>
 | |
|               </td>
 | |
|               <td class="bid text-right">
 | |
|                 <span class="skeleton-loader" style="max-width: 100px"></span>
 | |
|               </td>
 | |
|               <td class="time text-right">
 | |
|                 <span class="skeleton-loader" style="max-width: 100px"></span>
 | |
|               </td>
 | |
|             </tr>
 | |
|           </tbody>
 | |
|         }
 | |
|       </ng-template>
 | |
|     </table>
 | |
| 
 | |
|     <ngb-pagination *ngIf="!widget" class="pagination-container float-right mt-2" [class]="isLoading ? 'disabled' : ''"
 | |
|       [collectionSize]="this.accelerationCount" [rotate]="true" [maxSize]="maxSize" [pageSize]="15" [(page)]="page"
 | |
|       (pageChange)="pageChange(page)" [boundaryLinks]="true" [ellipses]="false">
 | |
|     </ngb-pagination>
 | |
| 
 | |
|     <ng-template [ngIf]="!widget">
 | |
|       <div class="clearfix"></div>
 | |
|       <br>
 | |
|     </ng-template>
 | |
|   </div>
 | |
| 
 | |
|   <ng-template #noData>
 | |
|     <div class="no-data">
 | |
|       <span *ngIf="pending" i18n="accelerations.no-accelerations">There are no active accelerations</span>
 | |
|       <span *ngIf="!pending" i18n="accelerations.no-accelerations">There are no recent accelerations</span>
 | |
|     </div>
 | |
|   </ng-template>
 | |
|   
 | |
| </div>
 |