Browse Source
			
			
			Bugfix/fix undefined currencies after creating an activity (#731)
			
				* Fix issue with undefined currencies after creating an activity
* Update changelog
			
			
				pull/732/head
			
			
		 
		
			
				
					
						 Thomas Kaul
					
					4 years ago
						Thomas Kaul
					
					4 years ago
					
						
							committed by
							
								 GitHub
								GitHub
							
						 
					
				 
				
			 
		 
		
			
				
					
					No known key found for this signature in database
					
						
							GPG Key ID: 4AEE18F83AFDEB23
						
					
				
			
		
		
		
	
		
			
				 3 changed files with 
16 additions and 
8 deletions
			 
			
		 
		
			
				- 
					
					
					 
					CHANGELOG.md
				
- 
					
					
					 
					apps/api/src/app/order/order.service.ts
				
- 
					
					
					 
					apps/api/src/services/exchange-rate-data.service.ts
				
				
				
					
						
							
								
									
	
		
			
				
					|  |  | @ -11,6 +11,10 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | - Added support for click in the portfolio proportion chart component | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | ### Fixed | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | - Fixed an issue with undefined currencies after creating an activity | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | ## 1.121.0 - 27.02.2022 | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | ### Added | 
			
		
	
	
		
			
				
					|  |  | 
 | 
			
		
	
								
							
						
					 
					
				 
			 
		
			
			
			
			
			
			
				
				
					
						
							
								
									
	
		
			
				
					|  |  | @ -93,6 +93,13 @@ export class OrderService { | 
			
		
	
		
			
				
					|  |  |  |         data.SymbolProfile.connectOrCreate.create.symbol.toUpperCase(); | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     await this.dataGatheringService.gatherProfileData([ | 
			
		
	
		
			
				
					|  |  |  |       { | 
			
		
	
		
			
				
					|  |  |  |         dataSource: data.dataSource, | 
			
		
	
		
			
				
					|  |  |  |         symbol: data.SymbolProfile.connectOrCreate.create.symbol | 
			
		
	
		
			
				
					|  |  |  |       } | 
			
		
	
		
			
				
					|  |  |  |     ]); | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     const isDraft = isAfter(data.date as Date, endOfToday()); | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     if (!isDraft) { | 
			
		
	
	
		
			
				
					|  |  | @ -106,13 +113,6 @@ export class OrderService { | 
			
		
	
		
			
				
					|  |  |  |       ]); | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     this.dataGatheringService.gatherProfileData([ | 
			
		
	
		
			
				
					|  |  |  |       { | 
			
		
	
		
			
				
					|  |  |  |         dataSource: data.dataSource, | 
			
		
	
		
			
				
					|  |  |  |         symbol: data.SymbolProfile.connectOrCreate.create.symbol | 
			
		
	
		
			
				
					|  |  |  |       } | 
			
		
	
		
			
				
					|  |  |  |     ]); | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     await this.cacheService.flush(); | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     delete data.accountId; | 
			
		
	
	
		
			
				
					|  |  | 
 | 
			
		
	
								
							
						
					 
					
				 
			 
		
			
			
			
			
			
			
				
				
					
						
							
								
									
	
		
			
				
					|  |  | @ -114,6 +114,10 @@ export class ExchangeRateDataService { | 
			
		
	
		
			
				
					|  |  |  |     aFromCurrency: string, | 
			
		
	
		
			
				
					|  |  |  |     aToCurrency: string | 
			
		
	
		
			
				
					|  |  |  |   ) { | 
			
		
	
		
			
				
					|  |  |  |     if (aValue === 0) { | 
			
		
	
		
			
				
					|  |  |  |       return 0; | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     const hasNaN = Object.values(this.exchangeRates).some((exchangeRate) => { | 
			
		
	
		
			
				
					|  |  |  |       return isNaN(exchangeRate); | 
			
		
	
		
			
				
					|  |  |  |     }); | 
			
		
	
	
		
			
				
					|  |  | @ -206,7 +210,7 @@ export class ExchangeRateDataService { | 
			
		
	
		
			
				
					|  |  |  |       currencies = currencies.concat(customCurrencies); | 
			
		
	
		
			
				
					|  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     return uniq(currencies).sort(); | 
			
		
	
		
			
				
					|  |  |  |     return uniq(currencies).filter(Boolean).sort(); | 
			
		
	
		
			
				
					|  |  |  |   } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |   private prepareCurrencyPairs(aCurrencies: string[]) { | 
			
		
	
	
		
			
				
					|  |  | 
 |