Fix pool page update on slug change
This commit is contained in:
		
							parent
							
								
									d57bd56743
								
							
						
					
					
						commit
						21f91bcb6e
					
				| @ -1,7 +1,7 @@ | |||||||
| import { ChangeDetectionStrategy, Component, Inject, Input, LOCALE_ID, OnInit } from '@angular/core'; | import { ChangeDetectionStrategy, Component, Inject, Input, LOCALE_ID, OnInit } from '@angular/core'; | ||||||
| import { ActivatedRoute } from '@angular/router'; | import { ActivatedRoute } from '@angular/router'; | ||||||
| import { echarts, EChartsOption } from '../../graphs/echarts'; | import { echarts, EChartsOption } from '../../graphs/echarts'; | ||||||
| import { BehaviorSubject, Observable, combineLatest, of, timer } from 'rxjs'; | import { BehaviorSubject, Observable, Subscription, combineLatest, of } from 'rxjs'; | ||||||
| import { catchError, distinctUntilChanged, filter, map, share, switchMap, tap } from 'rxjs/operators'; | import { catchError, distinctUntilChanged, filter, map, share, switchMap, tap } from 'rxjs/operators'; | ||||||
| import { BlockExtended, PoolStat } from '../../interfaces/node-api.interface'; | import { BlockExtended, PoolStat } from '../../interfaces/node-api.interface'; | ||||||
| import { ApiService } from '../../services/api.service'; | import { ApiService } from '../../services/api.service'; | ||||||
| @ -28,6 +28,7 @@ export class PoolComponent implements OnInit { | |||||||
|   gfg = true; |   gfg = true; | ||||||
| 
 | 
 | ||||||
|   formatNumber = formatNumber; |   formatNumber = formatNumber; | ||||||
|  |   slugSubscription: Subscription; | ||||||
|   poolStats$: Observable<PoolStat>; |   poolStats$: Observable<PoolStat>; | ||||||
|   blocks$: Observable<BlockExtended[]>; |   blocks$: Observable<BlockExtended[]>; | ||||||
|   oobFees$: Observable<AccelerationTotal[]>; |   oobFees$: Observable<AccelerationTotal[]>; | ||||||
| @ -56,38 +57,24 @@ export class PoolComponent implements OnInit { | |||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   ngOnInit(): void { |   ngOnInit(): void { | ||||||
|     this.poolStats$ = this.route.params.pipe(map((params) => params.slug)) |     this.slugSubscription = this.route.params.pipe(map((params) => params.slug)).subscribe((slug) => { | ||||||
|  |       this.isLoading = true; | ||||||
|  |       this.blocks = []; | ||||||
|  |       this.chartOptions = {};   | ||||||
|  |       this.slug = slug; | ||||||
|  |       this.initializeObservables(); | ||||||
|  |     }); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   initializeObservables(): void { | ||||||
|  |     this.poolStats$ = this.apiService.getPoolHashrate$(this.slug) | ||||||
|       .pipe( |       .pipe( | ||||||
|         switchMap((slug: any) => { |         switchMap((data) => { | ||||||
|           this.isLoading = true; |           this.isLoading = false; | ||||||
|           this.slug = slug; |           const hashrate = data.map(val => [val.timestamp * 1000, val.avgHashrate]); | ||||||
|           return this.apiService.getPoolHashrate$(this.slug) |           const share = data.map(val => [val.timestamp * 1000, val.share * 100]); | ||||||
|             .pipe( |           this.prepareChartOptions(hashrate, share); | ||||||
|               switchMap((data) => { |           return this.apiService.getPoolStats$(this.slug); | ||||||
|                 this.isLoading = false; |  | ||||||
|                 const hashrate = data.map(val => [val.timestamp * 1000, val.avgHashrate]); |  | ||||||
|                 const share = data.map(val => [val.timestamp * 1000, val.share * 100]); |  | ||||||
|                 this.prepareChartOptions(hashrate, share); |  | ||||||
|                 return [slug]; |  | ||||||
|               }), |  | ||||||
|               catchError(() => { |  | ||||||
|                 this.isLoading = false; |  | ||||||
|                 this.seoService.logSoft404(); |  | ||||||
|                 return of([slug]); |  | ||||||
|               }) |  | ||||||
|             ); |  | ||||||
|         }), |  | ||||||
|         switchMap((slug) => { |  | ||||||
|           return this.apiService.getPoolStats$(slug).pipe( |  | ||||||
|             catchError(() => { |  | ||||||
|               this.isLoading = false; |  | ||||||
|               this.seoService.logSoft404(); |  | ||||||
|               return of(null); |  | ||||||
|             }) |  | ||||||
|           ); |  | ||||||
|         }), |  | ||||||
|         tap(() => { |  | ||||||
|           this.loadMoreSubject.next(this.blocks[0]?.height); |  | ||||||
|         }), |         }), | ||||||
|         map((poolStats) => { |         map((poolStats) => { | ||||||
|           this.seoService.setTitle(poolStats.pool.name); |           this.seoService.setTitle(poolStats.pool.name); | ||||||
| @ -101,7 +88,12 @@ export class PoolComponent implements OnInit { | |||||||
|           return Object.assign({ |           return Object.assign({ | ||||||
|             logo: `/resources/mining-pools/` + poolStats.pool.slug + '.svg' |             logo: `/resources/mining-pools/` + poolStats.pool.slug + '.svg' | ||||||
|           }, poolStats); |           }, poolStats); | ||||||
|         }) |         }), | ||||||
|  |         catchError(() => { | ||||||
|  |           this.isLoading = false; | ||||||
|  |           this.seoService.logSoft404(); | ||||||
|  |           return of(null); | ||||||
|  |         }), | ||||||
|       ); |       ); | ||||||
| 
 | 
 | ||||||
|     this.blocks$ = this.loadMoreSubject |     this.blocks$ = this.loadMoreSubject | ||||||
| @ -328,4 +320,8 @@ export class PoolComponent implements OnInit { | |||||||
|   trackByBlock(index: number, block: BlockExtended) { |   trackByBlock(index: number, block: BlockExtended) { | ||||||
|     return block.height; |     return block.height; | ||||||
|   } |   } | ||||||
|  | 
 | ||||||
|  |   ngOnDestroy(): void { | ||||||
|  |     this.slugSubscription.unsubscribe(); | ||||||
|  |   } | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user