|
@ -1302,12 +1302,11 @@ export class PortfolioService { |
|
|
}: { |
|
|
}: { |
|
|
activities: OrderWithAccount[]; |
|
|
activities: OrderWithAccount[]; |
|
|
date?: Date; |
|
|
date?: Date; |
|
|
|
|
|
|
|
|
userCurrency: string; |
|
|
userCurrency: string; |
|
|
}) { |
|
|
}) { |
|
|
return activities |
|
|
return activities |
|
|
.filter((activity) => { |
|
|
.filter((activity) => { |
|
|
// Filter out all activities before given date and type dividend
|
|
|
// Filter out all activities before given date (drafts) and type dividend
|
|
|
return ( |
|
|
return ( |
|
|
isBefore(date, new Date(activity.date)) && |
|
|
isBefore(date, new Date(activity.date)) && |
|
|
activity.type === TypeOfOrder.DIVIDEND |
|
|
activity.type === TypeOfOrder.DIVIDEND |
|
@ -1431,7 +1430,7 @@ export class PortfolioService { |
|
|
}) { |
|
|
}) { |
|
|
return activities |
|
|
return activities |
|
|
.filter((activity) => { |
|
|
.filter((activity) => { |
|
|
// Filter out all activities before given date
|
|
|
// Filter out all activities before given date (drafts)
|
|
|
return isBefore(date, new Date(activity.date)); |
|
|
return isBefore(date, new Date(activity.date)); |
|
|
}) |
|
|
}) |
|
|
.map(({ fee, SymbolProfile }) => { |
|
|
.map(({ fee, SymbolProfile }) => { |
|
@ -1478,19 +1477,37 @@ export class PortfolioService { |
|
|
}; |
|
|
}; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
private getItems(orders: OrderWithAccount[], date = new Date(0)) { |
|
|
private getItems(activities: OrderWithAccount[], date = new Date(0)) { |
|
|
return orders |
|
|
return activities |
|
|
.filter((order) => { |
|
|
.filter((activity) => { |
|
|
// Filter out all orders before given date and type item
|
|
|
// Filter out all activities before given date (drafts) and type item
|
|
|
return ( |
|
|
return ( |
|
|
isBefore(date, new Date(order.date)) && |
|
|
isBefore(date, new Date(activity.date)) && |
|
|
order.type === TypeOfOrder.ITEM |
|
|
activity.type === TypeOfOrder.ITEM |
|
|
); |
|
|
); |
|
|
}) |
|
|
}) |
|
|
.map((order) => { |
|
|
.map(({ quantity, SymbolProfile, unitPrice }) => { |
|
|
return this.exchangeRateDataService.toCurrency( |
|
|
return this.exchangeRateDataService.toCurrency( |
|
|
new Big(order.quantity).mul(order.unitPrice).toNumber(), |
|
|
new Big(quantity).mul(unitPrice).toNumber(), |
|
|
order.SymbolProfile.currency, |
|
|
SymbolProfile.currency, |
|
|
|
|
|
this.request.user.Settings.settings.baseCurrency |
|
|
|
|
|
); |
|
|
|
|
|
}) |
|
|
|
|
|
.reduce( |
|
|
|
|
|
(previous, current) => new Big(previous).plus(current), |
|
|
|
|
|
new Big(0) |
|
|
|
|
|
); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private getLiabilities(activities: OrderWithAccount[]) { |
|
|
|
|
|
return activities |
|
|
|
|
|
.filter(({ type }) => { |
|
|
|
|
|
return type === TypeOfOrder.LIABILITY; |
|
|
|
|
|
}) |
|
|
|
|
|
.map(({ quantity, SymbolProfile, unitPrice }) => { |
|
|
|
|
|
return this.exchangeRateDataService.toCurrency( |
|
|
|
|
|
new Big(quantity).mul(unitPrice).toNumber(), |
|
|
|
|
|
SymbolProfile.currency, |
|
|
this.request.user.Settings.settings.baseCurrency |
|
|
this.request.user.Settings.settings.baseCurrency |
|
|
); |
|
|
); |
|
|
}) |
|
|
}) |
|
@ -1601,6 +1618,7 @@ export class PortfolioService { |
|
|
const fees = this.getFees({ activities, userCurrency }).toNumber(); |
|
|
const fees = this.getFees({ activities, userCurrency }).toNumber(); |
|
|
const firstOrderDate = activities[0]?.date; |
|
|
const firstOrderDate = activities[0]?.date; |
|
|
const items = this.getItems(activities).toNumber(); |
|
|
const items = this.getItems(activities).toNumber(); |
|
|
|
|
|
const liabilities = this.getLiabilities(activities).toNumber(); |
|
|
|
|
|
|
|
|
const totalBuy = this.getTotalByType(activities, userCurrency, 'BUY'); |
|
|
const totalBuy = this.getTotalByType(activities, userCurrency, 'BUY'); |
|
|
const totalSell = this.getTotalByType(activities, userCurrency, 'SELL'); |
|
|
const totalSell = this.getTotalByType(activities, userCurrency, 'SELL'); |
|
@ -1633,6 +1651,7 @@ export class PortfolioService { |
|
|
.plus(performanceInformation.performance.currentValue) |
|
|
.plus(performanceInformation.performance.currentValue) |
|
|
.plus(items) |
|
|
.plus(items) |
|
|
.plus(excludedAccountsAndActivities) |
|
|
.plus(excludedAccountsAndActivities) |
|
|
|
|
|
.minus(liabilities) |
|
|
.toNumber(); |
|
|
.toNumber(); |
|
|
|
|
|
|
|
|
const daysInMarket = differenceInDays(new Date(), firstOrderDate); |
|
|
const daysInMarket = differenceInDays(new Date(), firstOrderDate); |
|
@ -1659,6 +1678,7 @@ export class PortfolioService { |
|
|
fees, |
|
|
fees, |
|
|
firstOrderDate, |
|
|
firstOrderDate, |
|
|
items, |
|
|
items, |
|
|
|
|
|
liabilities, |
|
|
netWorth, |
|
|
netWorth, |
|
|
totalBuy, |
|
|
totalBuy, |
|
|
totalSell, |
|
|
totalSell, |
|
|