|  | @ -39,19 +39,20 @@ export class AnalysisPageComponent implements OnDestroy, OnInit { | 
			
		
	
		
		
			
				
					|  |  |   public dateRangeOptions = ToggleComponent.DEFAULT_DATE_RANGE_OPTIONS; |  |  |   public dateRangeOptions = ToggleComponent.DEFAULT_DATE_RANGE_OPTIONS; | 
			
		
	
		
		
			
				
					|  |  |   public daysInMarket: number; |  |  |   public daysInMarket: number; | 
			
		
	
		
		
			
				
					|  |  |   public deviceType: string; |  |  |   public deviceType: string; | 
			
		
	
		
		
			
				
					
					|  |  |   public dividendsByMonth: InvestmentItem[]; |  |  |   public dividendsByGroup: InvestmentItem[]; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |   public dividendTimelineDataLabel = $localize`Dividend`; |  |  |   public dividendTimelineDataLabel = $localize`Dividend`; | 
			
		
	
		
		
			
				
					|  |  |   public filters$ = new Subject<Filter[]>(); |  |  |   public filters$ = new Subject<Filter[]>(); | 
			
		
	
		
		
			
				
					|  |  |   public firstOrderDate: Date; |  |  |   public firstOrderDate: Date; | 
			
		
	
		
		
			
				
					|  |  |   public hasImpersonationId: boolean; |  |  |   public hasImpersonationId: boolean; | 
			
		
	
		
		
			
				
					|  |  |   public investments: InvestmentItem[]; |  |  |   public investments: InvestmentItem[]; | 
			
		
	
		
		
			
				
					|  |  |   public investmentTimelineDataLabel = $localize`Deposit`; |  |  |   public investmentTimelineDataLabel = $localize`Deposit`; | 
			
		
	
		
		
			
				
					
					|  |  |   public investmentsByMonth: InvestmentItem[]; |  |  |   public investmentsByGroup: InvestmentItem[]; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |   public isLoadingBenchmarkComparator: boolean; |  |  |   public isLoadingBenchmarkComparator: boolean; | 
			
		
	
		
		
			
				
					|  |  |   public isLoadingInvestmentChart: boolean; |  |  |   public isLoadingInvestmentChart: boolean; | 
			
		
	
		
		
			
				
					|  |  |   public mode: GroupBy = 'month'; |  |  |   public mode: GroupBy = 'month'; | 
			
		
	
		
		
			
				
					|  |  |   public modeOptions: ToggleOption[] = [ |  |  |   public modeOptions: ToggleOption[] = [ | 
			
		
	
		
		
			
				
					
					|  |  |     { label: $localize`Monthly`, value: 'month' } |  |  |     { label: $localize`Monthly`, value: 'month' }, | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  |     { label: $localize`Yearly`, value: 'year' } | 
			
		
	
		
		
			
				
					|  |  |   ]; |  |  |   ]; | 
			
		
	
		
		
			
				
					|  |  |   public performanceDataItems: HistoricalDataItem[]; |  |  |   public performanceDataItems: HistoricalDataItem[]; | 
			
		
	
		
		
			
				
					|  |  |   public performanceDataItemsInPercentage: HistoricalDataItem[]; |  |  |   public performanceDataItemsInPercentage: HistoricalDataItem[]; | 
			
		
	
	
		
		
			
				
					|  | @ -91,6 +92,17 @@ export class AnalysisPageComponent implements OnDestroy, OnInit { | 
			
		
	
		
		
			
				
					|  |  |       }); |  |  |       }); | 
			
		
	
		
		
			
				
					|  |  |   } |  |  |   } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |   get savingsRate() { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     const savingsRatePerMonth = | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       this.hasImpersonationId || this.user.settings.isRestrictedView | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         ? undefined | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         : this.user?.settings?.savingsRate; | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     return this.mode === 'year' | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       ? savingsRatePerMonth * 12 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       : savingsRatePerMonth; | 
			
		
	
		
		
			
				
					|  |  |  |  |  |   } | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |   public ngOnInit() { |  |  |   public ngOnInit() { | 
			
		
	
		
		
			
				
					|  |  |     this.deviceType = this.deviceService.getDeviceInfo().deviceType; |  |  |     this.deviceType = this.deviceService.getDeviceInfo().deviceType; | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  | @ -201,6 +213,7 @@ export class AnalysisPageComponent implements OnDestroy, OnInit { | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |   public onChangeGroupBy(aMode: GroupBy) { |  |  |   public onChangeGroupBy(aMode: GroupBy) { | 
			
		
	
		
		
			
				
					|  |  |     this.mode = aMode; |  |  |     this.mode = aMode; | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     this.fetchDividendsAndInvestments(); | 
			
		
	
		
		
			
				
					|  |  |   } |  |  |   } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |   public ngOnDestroy() { |  |  |   public ngOnDestroy() { | 
			
		
	
	
		
		
			
				
					|  | @ -208,6 +221,34 @@ export class AnalysisPageComponent implements OnDestroy, OnInit { | 
			
		
	
		
		
			
				
					|  |  |     this.unsubscribeSubject.complete(); |  |  |     this.unsubscribeSubject.complete(); | 
			
		
	
		
		
			
				
					|  |  |   } |  |  |   } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |   private fetchDividendsAndInvestments() { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     this.dataService | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       .fetchDividends({ | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         filters: this.activeFilters, | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         groupBy: this.mode, | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         range: this.user?.settings?.dateRange | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       }) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       .pipe(takeUntil(this.unsubscribeSubject)) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       .subscribe(({ dividends }) => { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         this.dividendsByGroup = dividends; | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         this.changeDetectorRef.markForCheck(); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       }); | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     this.dataService | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       .fetchInvestments({ | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         filters: this.activeFilters, | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         groupBy: this.mode, | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         range: this.user?.settings?.dateRange | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       }) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       .pipe(takeUntil(this.unsubscribeSubject)) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       .subscribe(({ investments }) => { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         this.investmentsByGroup = investments; | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         this.changeDetectorRef.markForCheck(); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |       }); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |   } | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |   private openPositionDialog({ |  |  |   private openPositionDialog({ | 
			
		
	
		
		
			
				
					|  |  |     dataSource, |  |  |     dataSource, | 
			
		
	
		
		
			
				
					|  |  |     symbol |  |  |     symbol | 
			
		
	
	
		
		
			
				
					|  | @ -291,32 +332,6 @@ export class AnalysisPageComponent implements OnDestroy, OnInit { | 
			
		
	
		
		
			
				
					|  |  |         this.changeDetectorRef.markForCheck(); |  |  |         this.changeDetectorRef.markForCheck(); | 
			
		
	
		
		
			
				
					|  |  |       }); |  |  |       }); | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |     this.dataService |  |  |  | 
			
		
	
		
		
			
				
					|  |  |       .fetchDividends({ |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         filters: this.activeFilters, |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         groupBy: 'month', |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         range: this.user?.settings?.dateRange |  |  |  | 
			
		
	
		
		
			
				
					|  |  |       }) |  |  |  | 
			
		
	
		
		
			
				
					|  |  |       .pipe(takeUntil(this.unsubscribeSubject)) |  |  |  | 
			
		
	
		
		
			
				
					|  |  |       .subscribe(({ dividends }) => { |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         this.dividendsByMonth = dividends; |  |  |  | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         this.changeDetectorRef.markForCheck(); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |       }); |  |  |  | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  |     this.dataService |  |  |  | 
			
		
	
		
		
			
				
					|  |  |       .fetchInvestments({ |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         filters: this.activeFilters, |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         groupBy: 'month', |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         range: this.user?.settings?.dateRange |  |  |  | 
			
		
	
		
		
			
				
					|  |  |       }) |  |  |  | 
			
		
	
		
		
			
				
					|  |  |       .pipe(takeUntil(this.unsubscribeSubject)) |  |  |  | 
			
		
	
		
		
			
				
					|  |  |       .subscribe(({ investments }) => { |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         this.investmentsByMonth = investments; |  |  |  | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  |         this.changeDetectorRef.markForCheck(); |  |  |  | 
			
		
	
		
		
			
				
					|  |  |       }); |  |  |  | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  |     this.dataService |  |  |     this.dataService | 
			
		
	
		
		
			
				
					|  |  |       .fetchPositions({ |  |  |       .fetchPositions({ | 
			
		
	
		
		
			
				
					|  |  |         filters: this.activeFilters, |  |  |         filters: this.activeFilters, | 
			
		
	
	
		
		
			
				
					|  | @ -340,6 +355,7 @@ export class AnalysisPageComponent implements OnDestroy, OnInit { | 
			
		
	
		
		
			
				
					|  |  |         this.changeDetectorRef.markForCheck(); |  |  |         this.changeDetectorRef.markForCheck(); | 
			
		
	
		
		
			
				
					|  |  |       }); |  |  |       }); | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     this.fetchDividendsAndInvestments(); | 
			
		
	
		
		
			
				
					|  |  |     this.changeDetectorRef.markForCheck(); |  |  |     this.changeDetectorRef.markForCheck(); | 
			
		
	
		
		
			
				
					|  |  |   } |  |  |   } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  | 
 |