Simplify advanced acceleration
This commit is contained in:
		
							parent
							
								
									0b608c96dd
								
							
						
					
					
						commit
						a8d2138404
					
				| @ -4,7 +4,7 @@ | |||||||
|   width: 120px; |   width: 120px; | ||||||
|   margin-left: 4em; |   margin-left: 4em; | ||||||
|   margin-right: 1.5em; |   margin-right: 1.5em; | ||||||
|   padding-bottom: 63px; |   padding-bottom: 17px; | ||||||
| 
 | 
 | ||||||
|   .column { |   .column { | ||||||
|     width: 100%; |     width: 100%; | ||||||
|  | |||||||
| @ -32,56 +32,56 @@ | |||||||
|         <div class="alert alert-mempool">You are currently on the waitlist</div> |         <div class="alert alert-mempool">You are currently on the waitlist</div> | ||||||
|       </div> |       </div> | ||||||
| 
 | 
 | ||||||
|       <h5 i18n="accelerator.your-transaction">Your transaction</h5> |       <ng-template [ngIf]="showDetails"> | ||||||
|       <div class="row"> |         <h5 i18n="accelerator.your-transaction">Your transaction</h5> | ||||||
|         <div class="col"> |         <div class="row"> | ||||||
|           <small *ngIf="hasAncestors" class="form-text text-muted mb-2"> |           <div class="col"> | ||||||
|             <ng-container i18n="accelerator.plus-unconfirmed-ancestors">Plus {{ estimate.txSummary.ancestorCount - 1 }} unconfirmed ancestor(s)</ng-container> |             <small *ngIf="hasAncestors" class="form-text text-muted mb-2"> | ||||||
|           </small> |               <ng-container i18n="accelerator.plus-unconfirmed-ancestors">Plus {{ estimate.txSummary.ancestorCount - 1 }} unconfirmed ancestor(s)</ng-container> | ||||||
|           <table class="table table-borderless table-border table-dark table-background table-accelerator"> |             </small> | ||||||
|             <tbody> |             <table class="table table-borderless table-border table-dark table-background table-accelerator"> | ||||||
|               <tr class="group-first"> |               <tbody> | ||||||
|                 <td class="item" i18n="transaction.vsize|Transaction Virtual Size">Virtual size</td> |                 <tr class="group-first"> | ||||||
|                 <td style="text-align: end;" [innerHTML]="'‎' + (estimate.txSummary.effectiveVsize | vbytes: 2)"></td> |                   <td class="item" i18n="transaction.vsize|Transaction Virtual Size">Virtual size</td> | ||||||
|               </tr> |                   <td style="text-align: end;" [innerHTML]="'‎' + (estimate.txSummary.effectiveVsize | vbytes: 2)"></td> | ||||||
|               <tr class="info"> |                 </tr> | ||||||
|                 <td class="info" colspan=3> |                 <tr class="info"> | ||||||
|                   <i><small i18n="accelerator.transaction-vbytes-size-description">Size in vbytes of this transaction (including unconfirmed ancestors)</small></i> |                   <td class="info" colspan=3> | ||||||
|                 </td> |                     <i><small i18n="accelerator.transaction-vbytes-size-description">Size in vbytes of this transaction (including unconfirmed ancestors)</small></i> | ||||||
|               </tr> |                   </td> | ||||||
|               <tr> |                 </tr> | ||||||
|                 <td class="item" i18n="accelerator.in-band-fees">In-band fees</td> |                 <tr> | ||||||
|                 <td style="text-align: end;"> |                   <td class="item" i18n="accelerator.in-band-fees">In-band fees</td> | ||||||
|                   {{ estimate.txSummary.effectiveFee | number : '1.0-0' }} <span class="symbol" i18n="shared.sats">sats</span> |                   <td style="text-align: end;"> | ||||||
|                 </td> |                     {{ estimate.txSummary.effectiveFee | number : '1.0-0' }} <span class="symbol" i18n="shared.sats">sats</span> | ||||||
|               </tr> |                   </td> | ||||||
|               <tr class="info group-last"> |                 </tr> | ||||||
|                 <td class="info" colspan=3> |                 <tr class="info group-last"> | ||||||
|                   <i><small i18n="accelerator.fees-already-paid-description">Fees already paid by this transaction (including unconfirmed ancestors)</small></i> |                   <td class="info" colspan=3> | ||||||
|                 </td> |                     <i><small i18n="accelerator.fees-already-paid-description">Fees already paid by this transaction (including unconfirmed ancestors)</small></i> | ||||||
|               </tr> |                   </td> | ||||||
|             </tbody> |                 </tr> | ||||||
|           </table> |               </tbody> | ||||||
|  |             </table> | ||||||
|  |           </div> | ||||||
|         </div> |         </div> | ||||||
|       </div> |         <br> | ||||||
|       <br> |       </ng-template> | ||||||
|       <h5 *ngIf="estimate?.pools?.length" i18n="accelerator.how-much-faster">How much faster?</h5> |       <h5 *ngIf="estimate?.pools?.length" i18n="accelerator.how-much-faster">How much faster?</h5> | ||||||
|       <div class="row"> |       <div class="row"> | ||||||
|         <div class="col"> |         <div class="col"> | ||||||
|           <ng-container *ngIf="(etaInfo$ | async) as etaInfo; else loadingEstimate"> |           <ng-container *ngIf="(etaInfo$ | async) as etaInfo; else loadingEstimate"> | ||||||
|             <small class="form-text text-muted mb-2" i18n="accelerator.hashrate-percentage-description">Your transaction will be prioritized by up to {{ etaInfo.hashratePercentage | number : '1.1-1' }}% of miners.</small> |             <small class="form-text text-muted mb-2" i18n="accelerator.hashrate-percentage-description">Your transaction will be prioritized by up to <strong>{{ etaInfo.hashratePercentage | number : '1.1-1' }}%</strong> of miners.</small> | ||||||
|             <small class="form-text text-muted mb-2" i18n="accelerator.time-estimate-description">This will reduce your expected waiting time until the first confirmation to <app-time kind="within" [time]="etaInfo.acceleratedETA" [fastRender]="false" [fixedRender]="true"></app-time></small> |             <small class="form-text text-muted mb-2" i18n="accelerator.time-estimate-description">This will reduce your expected waiting time until the first confirmation to <strong><app-time kind="within" [time]="etaInfo.acceleratedETA" [fastRender]="false" [fixedRender]="true"></app-time></strong></small> | ||||||
|           </ng-container> |           </ng-container> | ||||||
|         </div> |         </div> | ||||||
|         <div class="col pie"> |         <div class="col pie"> | ||||||
|           <app-active-acceleration-box [miningStats]="miningStats" [pools]="estimate.pools" [chartOnly]="true"></app-active-acceleration-box> |           <app-active-acceleration-box [miningStats]="miningStats" [pools]="estimate.pools" [chartOnly]="true"></app-active-acceleration-box> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|       <br> | 
 | ||||||
|       <h5 i18n="accelerator.pay-how-much">How much more are you willing to pay?</h5> |  | ||||||
|       <div class="row"> |       <div class="row"> | ||||||
|         <div class="col"> |         <div class="col"> | ||||||
|           <small class="form-text text-muted mb-2" i18n="accelerator.transaction-fee-description">Choose the maximum extra transaction fee you're willing to pay.</small> |  | ||||||
|           <div class="form-group"> |           <div class="form-group"> | ||||||
|             <div class="fee-card"> |             <div class="fee-card"> | ||||||
|               <div class="d-flex mb-0"> |               <div class="d-flex mb-0"> | ||||||
| @ -97,13 +97,13 @@ | |||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|    |    | ||||||
|       <h5>Acceleration summary</h5> |       <h5>Summary</h5> | ||||||
|       <div class="row mb-3"> |       <div class="row mb-3"> | ||||||
|         <div class="col"> |         <div class="col"> | ||||||
|           <table class="table table-borderless table-border table-dark table-background table-accelerator"> |           <table class="table table-borderless table-border table-dark table-background table-accelerator"> | ||||||
|             <tbody> |             <tbody> | ||||||
|               <!-- ESTIMATED FEE --> |               <!-- ESTIMATED FEE --> | ||||||
|               <ng-container> |               <ng-template [ngIf]="showDetails"> | ||||||
|                 <tr class="group-first"> |                 <tr class="group-first"> | ||||||
|                   <td class="item" i18n="accelerator.next-block-rate">Next block market rate</td> |                   <td class="item" i18n="accelerator.next-block-rate">Next block market rate</td> | ||||||
|                   <td class="amt" style="font-size: 16px"> |                   <td class="amt" style="font-size: 16px"> | ||||||
| @ -123,24 +123,23 @@ | |||||||
|                     <span class="fiat ml-1"><app-fiat [value]="math.max(0, estimate.nextBlockFee - estimate.txSummary.effectiveFee)"></app-fiat></span> |                     <span class="fiat ml-1"><app-fiat [value]="math.max(0, estimate.nextBlockFee - estimate.txSummary.effectiveFee)"></app-fiat></span> | ||||||
|                   </td> |                   </td> | ||||||
|                 </tr> |                 </tr> | ||||||
|               </ng-container> |                  | ||||||
|    |                 <!-- MEMPOOL BASE FEE --> | ||||||
|               <!-- MEMPOOL BASE FEE --> |                 <tr> | ||||||
|               <tr> |                   <td class="item" i18n="accelerator.mempool-accelerator-fees">Mempool Accelerator™ fees</td> | ||||||
|                 <td class="item" i18n="accelerator.mempool-accelerator-fees">Mempool Accelerator™ fees</td> |                 </tr> | ||||||
|               </tr> |                 <tr class="info"> | ||||||
|               <tr class="info"> |                   <td class="info"> | ||||||
|                 <td class="info"> |                     <i><small i18n="accelerator.service-fee">Accelerator Service Fee</small></i> | ||||||
|                   <i><small i18n="accelerator.service-fee">Accelerator Service Fee</small></i> |                   </td> | ||||||
|                 </td> |                   <td class="amt"> | ||||||
|                 <td class="amt"> |                     +{{ estimate.mempoolBaseFee | number }} | ||||||
|                   +{{ estimate.mempoolBaseFee | number }} |                   </td> | ||||||
|                 </td> |                   <td class="units"> | ||||||
|                 <td class="units"> |                     <span class="symbol" i18n="shared.sats">sats</span> | ||||||
|                   <span class="symbol" i18n="shared.sats">sats</span> |                     <span class="fiat ml-1"><app-fiat [value]="estimate.mempoolBaseFee"></app-fiat></span> | ||||||
|                   <span class="fiat ml-1"><app-fiat [value]="estimate.mempoolBaseFee"></app-fiat></span> |                   </td> | ||||||
|                 </td> |                 </tr> | ||||||
|               </tr> |  | ||||||
|               <tr class="info group-last"> |               <tr class="info group-last"> | ||||||
|                 <td class="info"> |                 <td class="info"> | ||||||
|                   <i><small i18n="accelerator.tx-size-surcharge">Transaction Size Surcharge</small></i> |                   <i><small i18n="accelerator.tx-size-surcharge">Transaction Size Surcharge</small></i> | ||||||
| @ -153,13 +152,13 @@ | |||||||
|                   <span class="fiat ml-1"><app-fiat [value]="estimate.vsizeFee"></app-fiat></span> |                   <span class="fiat ml-1"><app-fiat [value]="estimate.vsizeFee"></app-fiat></span> | ||||||
|                 </td> |                 </td> | ||||||
|               </tr> |               </tr> | ||||||
| 
 |             </ng-template> | ||||||
|                |                | ||||||
|               <!-- NEXT BLOCK ESTIMATE --> |               <!-- NEXT BLOCK ESTIMATE --> | ||||||
|               <ng-container> |               <ng-container> | ||||||
|                 <tr class="group-first" style="border-top: 1px dashed grey; border-collapse: collapse;"> |                 <tr class="group-first"> | ||||||
|                   <td class="item"> |                   <td class="item"> | ||||||
|                     <b style="background-color: #5E35B1" class="p-1 pl-0" i18n="accelerator.estimated-cost">Estimated acceleration cost</b> |                     <b style="background-color: #5E35B1" class="p-1 pl-0" i18n="accelerator.estimated-cost">Estimated acceleration cost</b> ~{{ estimate.targetFeeRate | number : '1.0-0' }} sat/vB | ||||||
|                   </td> |                   </td> | ||||||
|                   <td class="amt"> |                   <td class="amt"> | ||||||
|                     <span style="background-color: #5E35B1" class="p-1 pl-0"> |                     <span style="background-color: #5E35B1" class="p-1 pl-0"> | ||||||
| @ -171,18 +170,13 @@ | |||||||
|                     <span class="fiat ml-1"><app-fiat [value]="estimate.cost + estimate.mempoolBaseFee + estimate.vsizeFee"></app-fiat></span> |                     <span class="fiat ml-1"><app-fiat [value]="estimate.cost + estimate.mempoolBaseFee + estimate.vsizeFee"></app-fiat></span> | ||||||
|                   </td> |                   </td> | ||||||
|                 </tr> |                 </tr> | ||||||
|                 <tr class="info group-last" style="border-bottom: 1px solid lightgrey"> |  | ||||||
|                   <td class="info" colspan=3> |  | ||||||
|                     <i><small><ng-container *ngTemplateOutlet="acceleratedTo; context: {$implicit: estimate.targetFeeRate }"></ng-container></small></i> |  | ||||||
|                   </td> |  | ||||||
|                 </tr> |  | ||||||
|               </ng-container> |               </ng-container> | ||||||
| 
 | 
 | ||||||
|               <!-- MAX COST --> |               <!-- MAX COST --> | ||||||
|               <ng-container> |               <ng-container> | ||||||
|                 <tr class="group-first"> |                 <tr class="group-first"> | ||||||
|                   <td class="item"> |                   <td class="item"> | ||||||
|                     <b style="background-color: var(--primary);" class="p-1 pl-0" i18n="accelerator.maximum-cost">Maximum acceleration cost</b> |                     <b style="background-color: var(--primary);" class="p-1 pl-0" i18n="accelerator.maximum-cost">Maximum acceleration cost</b>  | ||||||
|                   </td> |                   </td> | ||||||
|                   <td class="amt"> |                   <td class="amt"> | ||||||
|                     <span style="background-color: var(--primary)" class="p-1 pl-0"> |                     <span style="background-color: var(--primary)" class="p-1 pl-0"> | ||||||
| @ -196,11 +190,6 @@ | |||||||
|                     </span> |                     </span> | ||||||
|                   </td> |                   </td> | ||||||
|                 </tr> |                 </tr> | ||||||
|                 <tr class="info group-last"> |  | ||||||
|                   <td class="info" colspan=3> |  | ||||||
|                     <i><small><ng-container *ngTemplateOutlet="acceleratedTo; context: {$implicit: (estimate.txSummary.effectiveFee + userBid) / estimate.txSummary.effectiveVsize }"></ng-container></small></i> |  | ||||||
|                   </td> |  | ||||||
|                 </tr> |  | ||||||
|               </ng-container> |               </ng-container> | ||||||
|    |    | ||||||
|               <!-- USER BALANCE --> |               <!-- USER BALANCE --> | ||||||
| @ -218,7 +207,11 @@ | |||||||
|                   </td> |                   </td> | ||||||
|                 </tr> |                 </tr> | ||||||
|               </ng-container> |               </ng-container> | ||||||
| 
 |               <tr> | ||||||
|  |                 <td colspan="3"> | ||||||
|  |                   <div style="border-top: 1px dashed grey; margin-top: 10px;"></div> | ||||||
|  |                 </td> | ||||||
|  |               </tr> | ||||||
|               <!-- LOGIN CTA --> |               <!-- LOGIN CTA --> | ||||||
|               <ng-container *ngIf="stateService.isMempoolSpaceBuild && !isLoggedIn()"> |               <ng-container *ngIf="stateService.isMempoolSpaceBuild && !isLoggedIn()"> | ||||||
|                 <tr class="group-first group-last" style="border-top: 1px dashed grey"> |                 <tr class="group-first group-last" style="border-top: 1px dashed grey"> | ||||||
| @ -230,7 +223,7 @@ | |||||||
|                 </tr> |                 </tr> | ||||||
|               </ng-container> |               </ng-container> | ||||||
|               <ng-container *ngIf="!stateService.isMempoolSpaceBuild"> |               <ng-container *ngIf="!stateService.isMempoolSpaceBuild"> | ||||||
|                 <tr class="group-first group-last" style="border-top: 1px dashed grey"> |                 <tr class="group-first group-last"> | ||||||
|                   <td class="item"></td> |                   <td class="item"></td> | ||||||
|                   <td class="amt"></td> |                   <td class="amt"></td> | ||||||
|                   <td class="units d-flex"> |                   <td class="units d-flex"> | ||||||
| @ -258,6 +251,4 @@ | |||||||
| <ng-template #loadingEstimate> | <ng-template #loadingEstimate> | ||||||
|   <div class="skeleton-loader"></div> |   <div class="skeleton-loader"></div> | ||||||
|   <br> |   <br> | ||||||
| </ng-template> | </ng-template> | ||||||
| 
 |  | ||||||
| <ng-template #acceleratedTo let-i i18n="accelerator.accelerated-to-description">If your tx is accelerated to ~{{ i | number : '1.0-0' }} sat/vB</ng-template> |  | ||||||
| @ -118,4 +118,9 @@ | |||||||
| 
 | 
 | ||||||
| .table-background { | .table-background { | ||||||
|   background-color: var(--bg); |   background-color: var(--bg); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .col.pie { | ||||||
|  |   position: relative; | ||||||
|  |   top: -15px; | ||||||
| } | } | ||||||
| @ -46,6 +46,7 @@ export class AcceleratePreviewComponent implements OnInit, OnDestroy, OnChanges | |||||||
|   @Input() tx: Transaction; |   @Input() tx: Transaction; | ||||||
|   @Input() miningStats: MiningStats; |   @Input() miningStats: MiningStats; | ||||||
|   @Input() scrollEvent: boolean; |   @Input() scrollEvent: boolean; | ||||||
|  |   @Input() showDetails: boolean; | ||||||
| 
 | 
 | ||||||
|   math = Math; |   math = Math; | ||||||
|   error = ''; |   error = ''; | ||||||
|  | |||||||
| @ -80,10 +80,12 @@ | |||||||
|       <div class="title float-left"> |       <div class="title float-left"> | ||||||
|         <h2 i18n="transaction.accelerate|Accelerate button label">Accelerate</h2> |         <h2 i18n="transaction.accelerate|Accelerate button label">Accelerate</h2> | ||||||
|       </div> |       </div> | ||||||
|  |       <button type="button" class="btn btn-outline-info flow-toggle btn-sm float-right" (click)="showAccelerationDetails = !showAccelerationDetails" i18n="transaction.details|Transaction Details">Details</button> | ||||||
|  | 
 | ||||||
|       <div class="clearfix"></div> |       <div class="clearfix"></div> | ||||||
| 
 | 
 | ||||||
|       <div class="box"> |       <div class="box"> | ||||||
|         <app-accelerate-preview [tx]="tx" [miningStats]="miningStats" [scrollEvent]="scrollIntoAccelPreview"></app-accelerate-preview> |         <app-accelerate-preview [tx]="tx" [miningStats]="miningStats" [scrollEvent]="scrollIntoAccelPreview" [showDetails]="showAccelerationDetails"></app-accelerate-preview> | ||||||
|       </div> |       </div> | ||||||
|     </ng-container> |     </ng-container> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -138,6 +138,7 @@ export class TransactionComponent implements OnInit, AfterViewInit, OnDestroy { | |||||||
|   accelerateCtaType: 'alert' | 'button' = 'button'; |   accelerateCtaType: 'alert' | 'button' = 'button'; | ||||||
|   acceleratorAvailable: boolean = this.stateService.env.OFFICIAL_MEMPOOL_SPACE && this.stateService.env.ACCELERATOR && this.stateService.network === ''; |   acceleratorAvailable: boolean = this.stateService.env.OFFICIAL_MEMPOOL_SPACE && this.stateService.env.ACCELERATOR && this.stateService.network === ''; | ||||||
|   showAccelerationSummary = false; |   showAccelerationSummary = false; | ||||||
|  |   showAccelerationDetails = false; | ||||||
|   scrollIntoAccelPreview = false; |   scrollIntoAccelPreview = false; | ||||||
|   auditEnabled: boolean = this.stateService.env.AUDIT && this.stateService.env.BASE_MODULE === 'mempool' && this.stateService.env.MINING_DASHBOARD === true; |   auditEnabled: boolean = this.stateService.env.AUDIT && this.stateService.env.BASE_MODULE === 'mempool' && this.stateService.env.MINING_DASHBOARD === true; | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user