Merge branch 'master' into nymkappa/bugfix/fix-ln-label-y
This commit is contained in:
		
						commit
						b147898823
					
				| @ -521,7 +521,7 @@ class BlocksRepository { | |||||||
|         CAST(AVG(blocks.height) as INT) as avgHeight, |         CAST(AVG(blocks.height) as INT) as avgHeight, | ||||||
|         CAST(AVG(UNIX_TIMESTAMP(blockTimestamp)) as INT) as timestamp, |         CAST(AVG(UNIX_TIMESTAMP(blockTimestamp)) as INT) as timestamp, | ||||||
|         CAST(AVG(fees) as INT) as avgFees, |         CAST(AVG(fees) as INT) as avgFees, | ||||||
|         prices.* |         prices.USD | ||||||
|         FROM blocks |         FROM blocks | ||||||
|         JOIN blocks_prices on blocks_prices.height = blocks.height |         JOIN blocks_prices on blocks_prices.height = blocks.height | ||||||
|         JOIN prices on prices.id = blocks_prices.price_id |         JOIN prices on prices.id = blocks_prices.price_id | ||||||
| @ -550,7 +550,7 @@ class BlocksRepository { | |||||||
|         CAST(AVG(blocks.height) as INT) as avgHeight, |         CAST(AVG(blocks.height) as INT) as avgHeight, | ||||||
|         CAST(AVG(UNIX_TIMESTAMP(blockTimestamp)) as INT) as timestamp, |         CAST(AVG(UNIX_TIMESTAMP(blockTimestamp)) as INT) as timestamp, | ||||||
|         CAST(AVG(reward) as INT) as avgRewards, |         CAST(AVG(reward) as INT) as avgRewards, | ||||||
|         prices.* |         prices.USD | ||||||
|         FROM blocks |         FROM blocks | ||||||
|         JOIN blocks_prices on blocks_prices.height = blocks.height |         JOIN blocks_prices on blocks_prices.height = blocks.height | ||||||
|         JOIN prices on prices.id = blocks_prices.price_id |         JOIN prices on prices.id = blocks_prices.price_id | ||||||
|  | |||||||
| @ -1,19 +1,17 @@ | |||||||
| import { ChangeDetectionStrategy, Component, Inject, Input, LOCALE_ID, OnInit } from '@angular/core'; | import { ChangeDetectionStrategy, Component, Inject, Input, LOCALE_ID, OnInit } from '@angular/core'; | ||||||
| import { EChartsOption, graphic } from 'echarts'; | import { EChartsOption, graphic } from 'echarts'; | ||||||
| import { Observable, Subscription } from 'rxjs'; | import { Observable } from 'rxjs'; | ||||||
| import { map, share, startWith, switchMap, tap } from 'rxjs/operators'; | import { map, share, startWith, switchMap, tap } from 'rxjs/operators'; | ||||||
| import { ApiService } from '../../services/api.service'; | import { ApiService } from '../../services/api.service'; | ||||||
| import { SeoService } from '../../services/seo.service'; | import { SeoService } from '../../services/seo.service'; | ||||||
| import { formatNumber } from '@angular/common'; | import { formatNumber } from '@angular/common'; | ||||||
| import { UntypedFormBuilder, UntypedFormGroup } from '@angular/forms'; | import { UntypedFormBuilder, UntypedFormGroup } from '@angular/forms'; | ||||||
| import { download, formatterXAxis } from '../../shared/graphs.utils'; | import { download, formatterXAxis } from '../../shared/graphs.utils'; | ||||||
| import { StateService } from '../../services/state.service'; |  | ||||||
| import { StorageService } from '../../services/storage.service'; | import { StorageService } from '../../services/storage.service'; | ||||||
| import { MiningService } from '../../services/mining.service'; | import { MiningService } from '../../services/mining.service'; | ||||||
| import { ActivatedRoute } from '@angular/router'; | import { ActivatedRoute } from '@angular/router'; | ||||||
| import { FiatShortenerPipe } from '../../shared/pipes/fiat-shortener.pipe'; | import { FiatShortenerPipe } from '../../shared/pipes/fiat-shortener.pipe'; | ||||||
| import { FiatCurrencyPipe } from '../../shared/pipes/fiat-currency.pipe'; | import { FiatCurrencyPipe } from '../../shared/pipes/fiat-currency.pipe'; | ||||||
| import { fiatCurrencies } from '../../app.constants'; |  | ||||||
| 
 | 
 | ||||||
| @Component({ | @Component({ | ||||||
|   selector: 'app-block-fees-graph', |   selector: 'app-block-fees-graph', | ||||||
| @ -47,7 +45,6 @@ export class BlockFeesGraphComponent implements OnInit { | |||||||
|   timespan = ''; |   timespan = ''; | ||||||
|   chartInstance: any = undefined; |   chartInstance: any = undefined; | ||||||
| 
 | 
 | ||||||
|   currencySubscription: Subscription; |  | ||||||
|   currency: string; |   currency: string; | ||||||
| 
 | 
 | ||||||
|   constructor( |   constructor( | ||||||
| @ -57,22 +54,14 @@ export class BlockFeesGraphComponent implements OnInit { | |||||||
|     private formBuilder: UntypedFormBuilder, |     private formBuilder: UntypedFormBuilder, | ||||||
|     private storageService: StorageService, |     private storageService: StorageService, | ||||||
|     private miningService: MiningService, |     private miningService: MiningService, | ||||||
|     private stateService: StateService, |  | ||||||
|     private route: ActivatedRoute, |     private route: ActivatedRoute, | ||||||
|     private fiatShortenerPipe: FiatShortenerPipe, |     private fiatShortenerPipe: FiatShortenerPipe, | ||||||
|     private fiatCurrencyPipe: FiatCurrencyPipe, |     private fiatCurrencyPipe: FiatCurrencyPipe, | ||||||
|   ) { |   ) { | ||||||
|     this.radioGroupForm = this.formBuilder.group({ dateSpan: '1y' }); |     this.radioGroupForm = this.formBuilder.group({ dateSpan: '1y' }); | ||||||
|     this.radioGroupForm.controls.dateSpan.setValue('1y'); |     this.radioGroupForm.controls.dateSpan.setValue('1y'); | ||||||
| 
 |  | ||||||
|     this.currencySubscription = this.stateService.fiatCurrency$.subscribe((fiat) => { |  | ||||||
|       if (fiat && fiatCurrencies[fiat]?.indexed) { |  | ||||||
|         this.currency = fiat; |  | ||||||
|       } else { |  | ||||||
|     this.currency = 'USD'; |     this.currency = 'USD'; | ||||||
|   } |   } | ||||||
|     }); |  | ||||||
|   } |  | ||||||
| 
 | 
 | ||||||
|   ngOnInit(): void { |   ngOnInit(): void { | ||||||
|     this.seoService.setTitle($localize`:@@6c453b11fd7bd159ae30bc381f367bc736d86909:Block Fees`); |     this.seoService.setTitle($localize`:@@6c453b11fd7bd159ae30bc381f367bc736d86909:Block Fees`); | ||||||
|  | |||||||
| @ -1,19 +1,17 @@ | |||||||
| import { ChangeDetectionStrategy, Component, Inject, Input, LOCALE_ID, OnInit } from '@angular/core'; | import { ChangeDetectionStrategy, Component, Inject, Input, LOCALE_ID, OnInit } from '@angular/core'; | ||||||
| import { EChartsOption, graphic } from 'echarts'; | import { EChartsOption, graphic } from 'echarts'; | ||||||
| import { Observable, Subscription } from 'rxjs'; | import { Observable } from 'rxjs'; | ||||||
| import { map, share, startWith, switchMap, tap } from 'rxjs/operators'; | import { map, share, startWith, switchMap, tap } from 'rxjs/operators'; | ||||||
| import { ApiService } from '../../services/api.service'; | import { ApiService } from '../../services/api.service'; | ||||||
| import { SeoService } from '../../services/seo.service'; | import { SeoService } from '../../services/seo.service'; | ||||||
| import { formatNumber } from '@angular/common'; | import { formatNumber } from '@angular/common'; | ||||||
| import { UntypedFormBuilder, UntypedFormGroup } from '@angular/forms'; | import { UntypedFormBuilder, UntypedFormGroup } from '@angular/forms'; | ||||||
| import { download, formatterXAxis, formatterXAxisLabel, formatterXAxisTimeCategory } from '../../shared/graphs.utils'; | import { download, formatterXAxis } from '../../shared/graphs.utils'; | ||||||
| import { MiningService } from '../../services/mining.service'; | import { MiningService } from '../../services/mining.service'; | ||||||
| import { StateService } from '../../services/state.service'; |  | ||||||
| import { StorageService } from '../../services/storage.service'; | import { StorageService } from '../../services/storage.service'; | ||||||
| import { ActivatedRoute } from '@angular/router'; | import { ActivatedRoute } from '@angular/router'; | ||||||
| import { FiatShortenerPipe } from '../../shared/pipes/fiat-shortener.pipe'; | import { FiatShortenerPipe } from '../../shared/pipes/fiat-shortener.pipe'; | ||||||
| import { FiatCurrencyPipe } from '../../shared/pipes/fiat-currency.pipe'; | import { FiatCurrencyPipe } from '../../shared/pipes/fiat-currency.pipe'; | ||||||
| import { fiatCurrencies } from '../../app.constants'; |  | ||||||
| 
 | 
 | ||||||
| @Component({ | @Component({ | ||||||
|   selector: 'app-block-rewards-graph', |   selector: 'app-block-rewards-graph', | ||||||
| @ -47,7 +45,6 @@ export class BlockRewardsGraphComponent implements OnInit { | |||||||
|   timespan = ''; |   timespan = ''; | ||||||
|   chartInstance: any = undefined; |   chartInstance: any = undefined; | ||||||
| 
 | 
 | ||||||
|   currencySubscription: Subscription; |  | ||||||
|   currency: string; |   currency: string; | ||||||
| 
 | 
 | ||||||
|   constructor( |   constructor( | ||||||
| @ -56,20 +53,13 @@ export class BlockRewardsGraphComponent implements OnInit { | |||||||
|     private apiService: ApiService, |     private apiService: ApiService, | ||||||
|     private formBuilder: UntypedFormBuilder, |     private formBuilder: UntypedFormBuilder, | ||||||
|     private miningService: MiningService, |     private miningService: MiningService, | ||||||
|     private stateService: StateService, |  | ||||||
|     private storageService: StorageService, |     private storageService: StorageService, | ||||||
|     private route: ActivatedRoute, |     private route: ActivatedRoute, | ||||||
|     private fiatShortenerPipe: FiatShortenerPipe, |     private fiatShortenerPipe: FiatShortenerPipe, | ||||||
|     private fiatCurrencyPipe: FiatCurrencyPipe, |     private fiatCurrencyPipe: FiatCurrencyPipe, | ||||||
|   ) { |   ) { | ||||||
|     this.currencySubscription = this.stateService.fiatCurrency$.subscribe((fiat) => { |  | ||||||
|       if (fiat && fiatCurrencies[fiat]?.indexed) { |  | ||||||
|         this.currency = fiat; |  | ||||||
|       } else { |  | ||||||
|     this.currency = 'USD'; |     this.currency = 'USD'; | ||||||
|   } |   } | ||||||
|     }); |  | ||||||
|   } |  | ||||||
| 
 | 
 | ||||||
|   ngOnInit(): void { |   ngOnInit(): void { | ||||||
|     this.seoService.setTitle($localize`:@@8ba8fe810458280a83df7fdf4c614dfc1a826445:Block Rewards`); |     this.seoService.setTitle($localize`:@@8ba8fe810458280a83df7fdf4c614dfc1a826445:Block Rewards`); | ||||||
|  | |||||||
| @ -123,7 +123,7 @@ export class StartComponent implements OnInit, OnDestroy { | |||||||
|     this.minScrollWidth = this.firstPageWidth + (this.pageWidth * 2); |     this.minScrollWidth = this.firstPageWidth + (this.pageWidth * 2); | ||||||
| 
 | 
 | ||||||
|     if (firstVisibleBlock != null) { |     if (firstVisibleBlock != null) { | ||||||
|       this.scrollToBlock(firstVisibleBlock, offset); |       this.scrollToBlock(firstVisibleBlock, offset + (this.isMobile ? this.blockWidth : 0)); | ||||||
|     } else { |     } else { | ||||||
|       this.updatePages(); |       this.updatePages(); | ||||||
|     } |     } | ||||||
| @ -178,8 +178,10 @@ export class StartComponent implements OnInit, OnDestroy { | |||||||
|       setTimeout(() => { this.scrollToBlock(height, blockOffset); }, 50); |       setTimeout(() => { this.scrollToBlock(height, blockOffset); }, 50); | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     const targetHeight = this.isMobile ? height - 1 : height; |     if (this.isMobile) { | ||||||
|     const viewingPageIndex = this.getPageIndexOf(targetHeight); |       blockOffset -= this.blockWidth; | ||||||
|  |     } | ||||||
|  |     const viewingPageIndex = this.getPageIndexOf(height); | ||||||
|     const pages = []; |     const pages = []; | ||||||
|     this.pageIndex = Math.max(viewingPageIndex - 1, 0); |     this.pageIndex = Math.max(viewingPageIndex - 1, 0); | ||||||
|     let viewingPage = this.getPageAt(viewingPageIndex); |     let viewingPage = this.getPageAt(viewingPageIndex); | ||||||
| @ -189,7 +191,7 @@ export class StartComponent implements OnInit, OnDestroy { | |||||||
|       viewingPage = this.getPageAt(viewingPageIndex); |       viewingPage = this.getPageAt(viewingPageIndex); | ||||||
|     } |     } | ||||||
|     const left = viewingPage.offset - this.getConvertedScrollOffset(); |     const left = viewingPage.offset - this.getConvertedScrollOffset(); | ||||||
|     const blockIndex = viewingPage.height - targetHeight; |     const blockIndex = viewingPage.height - height; | ||||||
|     const targetOffset = (this.blockWidth * blockIndex) + left; |     const targetOffset = (this.blockWidth * blockIndex) + left; | ||||||
|     let deltaOffset = targetOffset - blockOffset; |     let deltaOffset = targetOffset - blockOffset; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -196,8 +196,8 @@ export class TxBowtieGraphComponent implements OnInit, OnChanges { | |||||||
|     this.outputs = this.initLines('out', voutWithFee, totalValue, this.maxStrands); |     this.outputs = this.initLines('out', voutWithFee, totalValue, this.maxStrands); | ||||||
| 
 | 
 | ||||||
|     this.middle = { |     this.middle = { | ||||||
|       path: `M ${(this.width / 2) - this.midWidth} ${(this.height / 2) + 0.5} L ${(this.width / 2) + this.midWidth} ${(this.height / 2) + 0.5}`, |       path: `M ${(this.width / 2) - this.midWidth} ${(this.height / 2) + 0.25} L ${(this.width / 2) + this.midWidth} ${(this.height / 2) + 0.25}`, | ||||||
|       style: `stroke-width: ${this.combinedWeight + 1}; stroke: ${this.gradient[1]}` |       style: `stroke-width: ${this.combinedWeight + 0.5}; stroke: ${this.gradient[1]}` | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     this.hasLine = this.inputs.reduce((line, put) => line || !put.zeroValue, false) |     this.hasLine = this.inputs.reduce((line, put) => line || !put.zeroValue, false) | ||||||
| @ -254,7 +254,7 @@ export class TxBowtieGraphComponent implements OnInit, OnChanges { | |||||||
|     const lineParams = weights.map((w, i) => { |     const lineParams = weights.map((w, i) => { | ||||||
|       return { |       return { | ||||||
|         weight: w, |         weight: w, | ||||||
|         thickness: xputs[i].value === 0 ? this.zeroValueThickness : Math.max(this.minWeight - 1, w) + 1, |         thickness: xputs[i].value === 0 ? this.zeroValueThickness : Math.min(this.combinedWeight + 0.5, Math.max(this.minWeight - 1, w) + 1), | ||||||
|         offset: 0, |         offset: 0, | ||||||
|         innerY: 0, |         innerY: 0, | ||||||
|         outerY: 0, |         outerY: 0, | ||||||
| @ -266,7 +266,7 @@ export class TxBowtieGraphComponent implements OnInit, OnChanges { | |||||||
| 
 | 
 | ||||||
|     // bounds of the middle segment
 |     // bounds of the middle segment
 | ||||||
|     const innerTop = (this.height / 2) - (this.combinedWeight / 2); |     const innerTop = (this.height / 2) - (this.combinedWeight / 2); | ||||||
|     const innerBottom = innerTop + this.combinedWeight; |     const innerBottom = innerTop + this.combinedWeight + 0.5; | ||||||
|     // tracks the visual bottom of the endpoints of the previous line
 |     // tracks the visual bottom of the endpoints of the previous line
 | ||||||
|     let lastOuter = 0; |     let lastOuter = 0; | ||||||
|     let lastInner = innerTop; |     let lastInner = innerTop; | ||||||
| @ -291,7 +291,7 @@ export class TxBowtieGraphComponent implements OnInit, OnChanges { | |||||||
| 
 | 
 | ||||||
|       // set the vertical position of the (center of the) outer side of the line
 |       // set the vertical position of the (center of the) outer side of the line
 | ||||||
|       line.outerY = lastOuter + (line.thickness / 2); |       line.outerY = lastOuter + (line.thickness / 2); | ||||||
|       line.innerY = Math.min(innerBottom + (line.thickness / 2), Math.max(innerTop + (line.thickness / 2), lastInner + (line.weight / 2))); |       line.innerY = Math.min(innerBottom - (line.thickness / 2), Math.max(innerTop + (line.thickness / 2), lastInner + (line.weight / 2))); | ||||||
| 
 | 
 | ||||||
|       // special case to center single input/outputs
 |       // special case to center single input/outputs
 | ||||||
|       if (xputs.length === 1) { |       if (xputs.length === 1) { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user