taxtank-core 0.28.85 → 0.28.87
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/taxtank-core.umd.js +77 -44
- package/bundles/taxtank-core.umd.js.map +1 -1
- package/esm2015/lib/collections/property/property-category-movement.collection.js +2 -2
- package/esm2015/lib/collections/transaction/transaction.collection.js +4 -12
- package/esm2015/lib/models/event/app-event-type.enum.js +20 -18
- package/esm2015/lib/models/property/property.js +2 -2
- package/esm2015/lib/services/http/sole/sole-invoice/sole-invoice.service.js +12 -1
- package/esm2015/lib/services/http/subscription/subscription.service.js +16 -10
- package/esm2015/lib/services/http/transaction/transaction-allocation/transaction-allocation.service.js +21 -1
- package/esm2015/lib/services/property/property-calculation/property-calculation.service.js +3 -3
- package/fesm2015/taxtank-core.js +69 -40
- package/fesm2015/taxtank-core.js.map +1 -1
- package/lib/collections/transaction/transaction.collection.d.ts +1 -9
- package/lib/models/event/app-event-type.enum.d.ts +19 -17
- package/lib/services/http/sole/sole-invoice/sole-invoice.service.d.ts +4 -1
- package/lib/services/http/subscription/subscription.service.d.ts +7 -5
- package/lib/services/http/transaction/transaction-allocation/transaction-allocation.service.d.ts +3 -0
- package/package.json +1 -1
|
@@ -3,6 +3,7 @@ import { TransactionAllocation } from '../../../../models/transaction/transactio
|
|
|
3
3
|
import { AppEventTypeEnum } from '../../../../models/event/app-event-type.enum';
|
|
4
4
|
import { RestService } from '../../rest/rest.service';
|
|
5
5
|
import { map } from 'rxjs/operators';
|
|
6
|
+
import { AppEvent } from '../../../../models/event/app-event';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
// @TODO Don't look at the commented code. Will be refactored/removed during TT-1503
|
|
8
9
|
/**
|
|
@@ -22,6 +23,25 @@ export class TransactionAllocationService extends RestService {
|
|
|
22
23
|
add(allocation) {
|
|
23
24
|
return this.addBatch([allocation]).pipe(map((newAllocations) => newAllocations[0]));
|
|
24
25
|
}
|
|
26
|
+
addBatch(models, queryParams) {
|
|
27
|
+
return super.addBatch(models, queryParams)
|
|
28
|
+
.pipe(map((allocations) => {
|
|
29
|
+
this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.TRANSACTION_ALLOCATION_CREATED, allocations));
|
|
30
|
+
return allocations;
|
|
31
|
+
}));
|
|
32
|
+
}
|
|
33
|
+
delete(model) {
|
|
34
|
+
return super.delete(model)
|
|
35
|
+
.pipe(map(() => {
|
|
36
|
+
this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.TRANSACTION_ALLOCATION_DELETED, null));
|
|
37
|
+
}));
|
|
38
|
+
}
|
|
39
|
+
deleteBatch(models) {
|
|
40
|
+
return super.deleteBatch(models)
|
|
41
|
+
.pipe(map(() => {
|
|
42
|
+
this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.TRANSACTION_ALLOCATION_DELETED, null));
|
|
43
|
+
}));
|
|
44
|
+
}
|
|
25
45
|
/**
|
|
26
46
|
* get list of transactions allocations related with passed bank transactions list
|
|
27
47
|
*/
|
|
@@ -79,4 +99,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
|
|
|
79
99
|
providedIn: 'root'
|
|
80
100
|
}]
|
|
81
101
|
}] });
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-allocation.service.js","sourceRoot":"","sources":["../../../../../../../../projects/tt-core/src/lib/services/http/transaction/transaction-allocation/transaction-allocation.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { TransactionAllocation as TransactionAllocationBase } from '../../../../db/Models/transaction/transaction-allocation';\nimport { TransactionAllocation } from '../../../../models/transaction/transaction-allocation';\nimport { Transaction } from '../../../../models/transaction/transaction';\nimport { AppEventTypeEnum } from '../../../../models/event/app-event-type.enum';\nimport { RestService } from '../../rest/rest.service';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { IEventListener } from '../../../../interfaces/event-listener.interface';\nimport { AppEvent } from '../../../../models/event/app-event';\n\n// @TODO Don't look at the commented code. Will be refactored/removed during TT-1503\n\n/**\n * Service for transaction allocations business logic\n * @TODO alex refactor\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class TransactionAllocationService extends RestService<TransactionAllocationBase, TransactionAllocation> implements IEventListener {\n  // API URL param for transaction allocations\n  url: string = 'transactions-allocations';\n  modelClass = TransactionAllocation;\n\n  /**\n   * Add single transaction allocation\n   */\n  add(allocation: TransactionAllocation): Observable<TransactionAllocation> {\n    return this.addBatch([allocation]).pipe(\n      map((newAllocations: TransactionAllocation[]): TransactionAllocation => newAllocations[0])\n    );\n  }\n\n  addBatch(models: TransactionAllocation[], queryParams?: object): Observable<TransactionAllocation[]> {\n    return super.addBatch(models, queryParams)\n      .pipe(\n        map((allocations: TransactionAllocation[]) => {\n          this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.TRANSACTION_ALLOCATION_CREATED, allocations));\n          return allocations;\n        })\n      )\n  }\n\n  delete(model: TransactionAllocation): Observable<void> {\n    return super.delete(model)\n      .pipe(\n        map(() => {\n          this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.TRANSACTION_ALLOCATION_DELETED, null));\n        })\n      )\n  }\n\n  deleteBatch(models: TransactionAllocation[]): Observable<void> {\n    return super.deleteBatch(models)\n      .pipe(\n        map(() => {\n          this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.TRANSACTION_ALLOCATION_DELETED, null));\n        })\n      )\n  }\n\n  /**\n   * get list of transactions allocations related with passed bank transactions list\n   */\n  getByTransactions(transactions: Transaction[]): Observable<TransactionAllocation[]> {\n    const ids: number[] = transactions.map((transaction: Transaction) => transaction.id);\n    return this.get()\n      .pipe(\n        map((transactionAllocations: TransactionAllocation[]) => {\n          return transactionAllocations.filter((allocation: TransactionAllocation) => ids.includes(allocation.transaction.id));\n        })\n      );\n  }\n\n  listenEvents(): void {\n    this.onTransactionsCreated();\n    this.onDepreciationCreated();\n    this.onTransactionDeleted();\n  }\n\n  /**\n   * Reset cache on transactions created\n   */\n  private onTransactionsCreated(): void {\n    this.eventDispatcherService.on(AppEventTypeEnum.TRANSACTIONS_CREATED).subscribe((transactions: Transaction[]): void => {\n      // @TODO Alex hack: research and refactor cache update logic, dont reset cache each time transactions changed\n      if (transactions[0].isTransfer) {\n        return;\n      }\n      // Update allocations cache to synchronize data and fire subscriptions\n      this.resetCache();\n    });\n  }\n\n  /**\n   * Reset cache on depreciation created\n   */\n  private onDepreciationCreated(): void {\n    this.eventDispatcherService.on(AppEventTypeEnum.DEPRECIATIONS_CREATED).subscribe((): void => {\n      // @TODO Alex hack: research and refactor cache update logic, dont reset cache each time depreciations changed\n      // Update allocations cache to synchronize data and fire subscriptions\n      this.resetCache();\n    });\n  }\n\n  /**\n   * Reset cache on transaction deleted\n   */\n  private onTransactionDeleted(): void {\n    this.eventDispatcherService.on(AppEventTypeEnum.TRANSACTION_DELETED).subscribe((): void => {\n      // @TODO Alex hack: research and refactor cache update logic, dont reset cache each time transactions changed\n      // Update allocations cache to synchronize data and fire subscriptions\n      this.resetCache();\n    });\n  }\n}\n"]}
|
|
@@ -12,7 +12,7 @@ import * as i0 from "@angular/core";
|
|
|
12
12
|
export class PropertyCalculationService {
|
|
13
13
|
getTaxPosition(transactions, depreciations) {
|
|
14
14
|
// @TODO hack: math abs added because we have mismatching of real values signs
|
|
15
|
-
return transactions.
|
|
15
|
+
return transactions.grossClaimAmount - Math.abs(depreciations.claimAmount);
|
|
16
16
|
}
|
|
17
17
|
getTaxPosition$(transactions$, depreciations$) {
|
|
18
18
|
return combineLatest([
|
|
@@ -143,7 +143,7 @@ export class PropertyCalculationService {
|
|
|
143
143
|
if (!forecastedCashPosition) {
|
|
144
144
|
return 0;
|
|
145
145
|
}
|
|
146
|
-
return (transactions.
|
|
146
|
+
return (transactions.grossClaimAmount - forecastedCashPosition) / forecastedCashPosition;
|
|
147
147
|
}
|
|
148
148
|
/**
|
|
149
149
|
* Get Badge for single property in collection
|
|
@@ -175,4 +175,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
|
|
|
175
175
|
providedIn: 'root'
|
|
176
176
|
}]
|
|
177
177
|
}] });
|
|
178
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-calculation.service.js","sourceRoot":"","sources":["../../../../../../../projects/tt-core/src/lib/services/property/property-calculation/property-calculation.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { combineLatest, Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { BankAccountCollection } from '../../../collections/bank-account.collection';\nimport { DepreciationCollection } from '../../../collections/depreciation.collection';\nimport { LoanCollection } from '../../../collections/loan/loan.collection';\nimport { PropertyCollection } from '../../../collections/property/property.collection';\nimport { TransactionCollection } from '../../../collections/transaction/transaction.collection';\nimport { Property } from '../../../models/property/property';\nimport { BankAccount } from '../../../models/bank/bank-account';\nimport { Dictionary } from '../../../models/dictionary/dictionary';\nimport { Badge } from '../../../models/badge/badge';\nimport { BadgeColorEnum } from '../../../models/badge/badge-color.enum';\n\n/**\n * Service with calculations methods for properties related with other entities.\n * Logic here works like collections methods but for several entities\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class PropertyCalculationService {\n  getTaxPosition(transactions: TransactionCollection, depreciations: DepreciationCollection): number {\n    // @TODO hack: math abs added because we have mismatching of real values signs\n    return transactions.cashPosition - Math.abs(depreciations.claimAmount);\n  }\n\n  getTaxPosition$(\n    transactions$: Observable<TransactionCollection>,\n    depreciations$: Observable<DepreciationCollection>\n  ): Observable<number> {\n    return combineLatest([\n      transactions$,\n      depreciations$\n    ]).pipe(\n      map(([transactions, depreciations]: [TransactionCollection, DepreciationCollection]): number => {\n        return this.getTaxPosition(transactions, depreciations);\n      })\n    );\n  }\n\n  taxPositionGrowth(properties: PropertyCollection, transactions: TransactionCollection, depreciations: DepreciationCollection): number {\n    const forecastedTaxPosition: number = properties.sumBy('forecastedTaxPosition');\n    // check if forecastedTaxPosition = 0 to avoid division by zero\n    if (!forecastedTaxPosition) {\n      return 0;\n    }\n\n    return (this.getTaxPosition(transactions, depreciations) - forecastedTaxPosition) / forecastedTaxPosition;\n  }\n\n  taxPositionGrowth$(\n    properties$: Observable<PropertyCollection>,\n    transactions$: Observable<TransactionCollection>,\n    depreciations$: Observable<DepreciationCollection>\n  ): Observable<number> {\n    return combineLatest([\n      properties$,\n      transactions$,\n      depreciations$\n    ]).pipe(\n      map(([properties, transactions, depreciations]: [PropertyCollection, TransactionCollection, DepreciationCollection]): number => {\n        return this.taxPositionGrowth(properties, transactions, depreciations);\n      })\n    );\n  }\n\n  getRentalReturn(properties: PropertyCollection, transactions: TransactionCollection): number {\n    return transactions.claimIncome / properties.marketValue;\n  }\n\n  getLoanAmount(properties: PropertyCollection, bankAccounts: BankAccountCollection, loans: LoanCollection): number {\n    return properties.items.reduce((totalAmount: number, property: Property): number => {\n      return totalAmount + bankAccounts.items\n        .reduce((propertyAmount: number, bankAccount: BankAccount): number => {\n          return propertyAmount + bankAccount.getPropertyPercentage(property.id) * (loans.getByBankAccountId(bankAccount.id)?.amount || 0);\n        }, 0);\n    }, 0);\n  }\n\n  getLoanValue(properties: PropertyCollection, bankAccounts: BankAccountCollection): number {\n    return properties.items.reduce((totalAmount: number, property: Property): number => {\n      return totalAmount + bankAccounts.items\n        .reduce((propertyAmount: number, bankAccount: BankAccount): number => {\n          return propertyAmount + bankAccount.getPropertyBalanceAmount(property.id);\n        }, 0);\n    }, 0);\n  }\n\n  /**\n   * LVR\n   */\n\n  getLvr(properties: PropertyCollection, bankAccounts: BankAccountCollection): number {\n    // Math abs is required for correct percentage calculation\n    return Math.abs(this.getLoanValue(properties, bankAccounts)) / properties.marketValue;\n  }\n\n  getLvr$(\n    properties$: Observable<PropertyCollection>,\n    bankAccounts$: Observable<BankAccountCollection>\n  ): Observable<number> {\n    return combineLatest([\n      properties$,\n      bankAccounts$\n    ]).pipe(\n      map(([properties, bankAccounts]: [PropertyCollection, BankAccountCollection]): number => {\n        return this.getLvr(properties, bankAccounts);\n      })\n    );\n  }\n\n  getLvrCommencement(properties: PropertyCollection, loans: LoanCollection, bankAccounts: BankAccountCollection): number {\n    // Math abs is required for correct percentage calculation\n    return Math.abs(this.getLoanAmount(properties, bankAccounts, loans)) / properties.purchasePrice;\n  }\n\n  getLvrCommencement$(\n    properties$: Observable<PropertyCollection>,\n    bankAccounts$: Observable<BankAccountCollection>,\n    loans$: Observable<LoanCollection>\n  ): Observable<number> {\n    return combineLatest([\n      properties$,\n      bankAccounts$,\n      loans$\n    ]).pipe(\n      map(([properties, bankAccounts, loans]: [PropertyCollection, BankAccountCollection, LoanCollection]): number => {\n        return this.getLvrCommencement(properties, loans, bankAccounts);\n      })\n    );\n  }\n\n  getLvrGrowth(properties: PropertyCollection, bankAccounts: BankAccountCollection, loans: LoanCollection): number {\n    const lvr: number = this.getLvr(properties, bankAccounts);\n    const lvrCommencement: number = this.getLvrCommencement(properties, loans, bankAccounts);\n    if (!lvrCommencement) {\n      // check if lvrCommencement = 0 to avoid division by zero\n      return 0;\n    }\n\n    return (this.getLvr(properties, bankAccounts) - lvrCommencement) / lvrCommencement;\n  }\n\n  getLvrGrowth$(\n    properties$: Observable<PropertyCollection>,\n    bankAccounts$: Observable<BankAccountCollection>,\n    loans$: Observable<LoanCollection>\n  ): Observable<number> {\n    return combineLatest([\n      properties$,\n      bankAccounts$,\n      loans$\n    ]).pipe(\n      map(([properties, bankAccounts, loans]: [PropertyCollection, BankAccountCollection, LoanCollection]): number => {\n        return this.getLvrGrowth(properties, bankAccounts, loans);\n      })\n    );\n  }\n\n  /**\n   * Equity position = Market value - current loan value\n   */\n  getEquityPosition(properties: PropertyCollection, bankAccounts: BankAccountCollection): number {\n    // Math abs is required for correct percentage calculation\n    return properties.marketValue - Math.abs(this.getLoanValue(properties, bankAccounts));\n  }\n\n  /**\n   * Purchase Equity = Purchase price - initial loan value\n   */\n  getPurchaseEquity(properties: PropertyCollection, bankAccounts: BankAccountCollection, loans: LoanCollection): number {\n    // Math abs is required for correct percentage calculation\n    return properties.purchasePrice - Math.abs(this.getLoanAmount(properties, bankAccounts, loans));\n  }\n\n  getEquityGrowth(properties: PropertyCollection, bankAccounts: BankAccountCollection, loans: LoanCollection): number {\n    const purchaseEquity: number = this.getPurchaseEquity(properties, bankAccounts, loans);\n    // check if purchaseEquity = 0 to avoid division by zero\n    if (!purchaseEquity) {\n      return 0;\n    }\n\n    return (this.getEquityPosition(properties, bankAccounts) - purchaseEquity) / purchaseEquity;\n  }\n\n  /**\n   * Get dictionary of badges for each property in collection\n   */\n  getBadgesByProperty(properties: PropertyCollection, transactions: TransactionCollection, depreciations: DepreciationCollection): Dictionary<Badge> {\n    const badgesByProperty = new Dictionary([]);\n\n    properties.toArray().forEach((property: Property) => {\n      badgesByProperty.add(property.id, this.getBadge(property, properties, transactions, depreciations));\n    });\n\n    return badgesByProperty;\n  }\n\n  getCashPositionGrowth(properties: PropertyCollection, transactions: TransactionCollection): number {\n    const forecastedCashPosition: number = properties.sumBy('forecastedCashPosition');\n\n    // check if forecastedCashPosition = 0 to avoid division by zero\n    if (!forecastedCashPosition) {\n      return 0;\n    }\n\n    return (transactions.cashPosition - forecastedCashPosition) / forecastedCashPosition;\n  }\n\n  /**\n   * Get Badge for single property in collection\n   */\n  private getBadge(property: Property, properties: PropertyCollection, transactions: TransactionCollection, depreciations: DepreciationCollection): Badge {\n    // best performance properties could be only from active properties list\n    const activeProperties: PropertyCollection = properties.getActiveProperties();\n    const bestPerformanceGrowthProperty: Property = activeProperties.getBestPerformanceGrowthProperty();\n    const bestPerformanceTaxProperty: Property = activeProperties.getBestPerformanceTaxProperty(\n      transactions, depreciations\n    );\n\n    switch (true) {\n      case !property.isActive:\n        return new Badge('Inactive', BadgeColorEnum.GRAY);\n      case property.id === bestPerformanceTaxProperty.id && property.id === bestPerformanceGrowthProperty.id:\n        return new Badge('Best performance growth & tax', BadgeColorEnum.GOLD);\n      case property.id === bestPerformanceTaxProperty.id:\n        return new Badge('Best performance tax', BadgeColorEnum.GOLD);\n      case property.id === bestPerformanceGrowthProperty.id:\n        return new Badge('Best performance growth', BadgeColorEnum.GREEN);\n      default:\n        return new Badge('Monitoring performance');\n    }\n  }\n}\n"]}
|
|
178
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-calculation.service.js","sourceRoot":"","sources":["../../../../../../../projects/tt-core/src/lib/services/property/property-calculation/property-calculation.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { combineLatest, Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { BankAccountCollection } from '../../../collections/bank-account.collection';\nimport { DepreciationCollection } from '../../../collections/depreciation.collection';\nimport { LoanCollection } from '../../../collections/loan/loan.collection';\nimport { PropertyCollection } from '../../../collections/property/property.collection';\nimport { TransactionCollection } from '../../../collections/transaction/transaction.collection';\nimport { Property } from '../../../models/property/property';\nimport { BankAccount } from '../../../models/bank/bank-account';\nimport { Dictionary } from '../../../models/dictionary/dictionary';\nimport { Badge } from '../../../models/badge/badge';\nimport { BadgeColorEnum } from '../../../models/badge/badge-color.enum';\n\n/**\n * Service with calculations methods for properties related with other entities.\n * Logic here works like collections methods but for several entities\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class PropertyCalculationService {\n  getTaxPosition(transactions: TransactionCollection, depreciations: DepreciationCollection): number {\n    // @TODO hack: math abs added because we have mismatching of real values signs\n    return transactions.grossClaimAmount - Math.abs(depreciations.claimAmount);\n  }\n\n  getTaxPosition$(\n    transactions$: Observable<TransactionCollection>,\n    depreciations$: Observable<DepreciationCollection>\n  ): Observable<number> {\n    return combineLatest([\n      transactions$,\n      depreciations$\n    ]).pipe(\n      map(([transactions, depreciations]: [TransactionCollection, DepreciationCollection]): number => {\n        return this.getTaxPosition(transactions, depreciations);\n      })\n    );\n  }\n\n  taxPositionGrowth(properties: PropertyCollection, transactions: TransactionCollection, depreciations: DepreciationCollection): number {\n    const forecastedTaxPosition: number = properties.sumBy('forecastedTaxPosition');\n    // check if forecastedTaxPosition = 0 to avoid division by zero\n    if (!forecastedTaxPosition) {\n      return 0;\n    }\n\n    return (this.getTaxPosition(transactions, depreciations) - forecastedTaxPosition) / forecastedTaxPosition;\n  }\n\n  taxPositionGrowth$(\n    properties$: Observable<PropertyCollection>,\n    transactions$: Observable<TransactionCollection>,\n    depreciations$: Observable<DepreciationCollection>\n  ): Observable<number> {\n    return combineLatest([\n      properties$,\n      transactions$,\n      depreciations$\n    ]).pipe(\n      map(([properties, transactions, depreciations]: [PropertyCollection, TransactionCollection, DepreciationCollection]): number => {\n        return this.taxPositionGrowth(properties, transactions, depreciations);\n      })\n    );\n  }\n\n  getRentalReturn(properties: PropertyCollection, transactions: TransactionCollection): number {\n    return transactions.claimIncome / properties.marketValue;\n  }\n\n  getLoanAmount(properties: PropertyCollection, bankAccounts: BankAccountCollection, loans: LoanCollection): number {\n    return properties.items.reduce((totalAmount: number, property: Property): number => {\n      return totalAmount + bankAccounts.items\n        .reduce((propertyAmount: number, bankAccount: BankAccount): number => {\n          return propertyAmount + bankAccount.getPropertyPercentage(property.id) * (loans.getByBankAccountId(bankAccount.id)?.amount || 0);\n        }, 0);\n    }, 0);\n  }\n\n  getLoanValue(properties: PropertyCollection, bankAccounts: BankAccountCollection): number {\n    return properties.items.reduce((totalAmount: number, property: Property): number => {\n      return totalAmount + bankAccounts.items\n        .reduce((propertyAmount: number, bankAccount: BankAccount): number => {\n          return propertyAmount + bankAccount.getPropertyBalanceAmount(property.id);\n        }, 0);\n    }, 0);\n  }\n\n  /**\n   * LVR\n   */\n\n  getLvr(properties: PropertyCollection, bankAccounts: BankAccountCollection): number {\n    // Math abs is required for correct percentage calculation\n    return Math.abs(this.getLoanValue(properties, bankAccounts)) / properties.marketValue;\n  }\n\n  getLvr$(\n    properties$: Observable<PropertyCollection>,\n    bankAccounts$: Observable<BankAccountCollection>\n  ): Observable<number> {\n    return combineLatest([\n      properties$,\n      bankAccounts$\n    ]).pipe(\n      map(([properties, bankAccounts]: [PropertyCollection, BankAccountCollection]): number => {\n        return this.getLvr(properties, bankAccounts);\n      })\n    );\n  }\n\n  getLvrCommencement(properties: PropertyCollection, loans: LoanCollection, bankAccounts: BankAccountCollection): number {\n    // Math abs is required for correct percentage calculation\n    return Math.abs(this.getLoanAmount(properties, bankAccounts, loans)) / properties.purchasePrice;\n  }\n\n  getLvrCommencement$(\n    properties$: Observable<PropertyCollection>,\n    bankAccounts$: Observable<BankAccountCollection>,\n    loans$: Observable<LoanCollection>\n  ): Observable<number> {\n    return combineLatest([\n      properties$,\n      bankAccounts$,\n      loans$\n    ]).pipe(\n      map(([properties, bankAccounts, loans]: [PropertyCollection, BankAccountCollection, LoanCollection]): number => {\n        return this.getLvrCommencement(properties, loans, bankAccounts);\n      })\n    );\n  }\n\n  getLvrGrowth(properties: PropertyCollection, bankAccounts: BankAccountCollection, loans: LoanCollection): number {\n    const lvr: number = this.getLvr(properties, bankAccounts);\n    const lvrCommencement: number = this.getLvrCommencement(properties, loans, bankAccounts);\n    if (!lvrCommencement) {\n      // check if lvrCommencement = 0 to avoid division by zero\n      return 0;\n    }\n\n    return (this.getLvr(properties, bankAccounts) - lvrCommencement) / lvrCommencement;\n  }\n\n  getLvrGrowth$(\n    properties$: Observable<PropertyCollection>,\n    bankAccounts$: Observable<BankAccountCollection>,\n    loans$: Observable<LoanCollection>\n  ): Observable<number> {\n    return combineLatest([\n      properties$,\n      bankAccounts$,\n      loans$\n    ]).pipe(\n      map(([properties, bankAccounts, loans]: [PropertyCollection, BankAccountCollection, LoanCollection]): number => {\n        return this.getLvrGrowth(properties, bankAccounts, loans);\n      })\n    );\n  }\n\n  /**\n   * Equity position = Market value - current loan value\n   */\n  getEquityPosition(properties: PropertyCollection, bankAccounts: BankAccountCollection): number {\n    // Math abs is required for correct percentage calculation\n    return properties.marketValue - Math.abs(this.getLoanValue(properties, bankAccounts));\n  }\n\n  /**\n   * Purchase Equity = Purchase price - initial loan value\n   */\n  getPurchaseEquity(properties: PropertyCollection, bankAccounts: BankAccountCollection, loans: LoanCollection): number {\n    // Math abs is required for correct percentage calculation\n    return properties.purchasePrice - Math.abs(this.getLoanAmount(properties, bankAccounts, loans));\n  }\n\n  getEquityGrowth(properties: PropertyCollection, bankAccounts: BankAccountCollection, loans: LoanCollection): number {\n    const purchaseEquity: number = this.getPurchaseEquity(properties, bankAccounts, loans);\n    // check if purchaseEquity = 0 to avoid division by zero\n    if (!purchaseEquity) {\n      return 0;\n    }\n\n    return (this.getEquityPosition(properties, bankAccounts) - purchaseEquity) / purchaseEquity;\n  }\n\n  /**\n   * Get dictionary of badges for each property in collection\n   */\n  getBadgesByProperty(properties: PropertyCollection, transactions: TransactionCollection, depreciations: DepreciationCollection): Dictionary<Badge> {\n    const badgesByProperty = new Dictionary([]);\n\n    properties.toArray().forEach((property: Property) => {\n      badgesByProperty.add(property.id, this.getBadge(property, properties, transactions, depreciations));\n    });\n\n    return badgesByProperty;\n  }\n\n  getCashPositionGrowth(properties: PropertyCollection, transactions: TransactionCollection): number {\n    const forecastedCashPosition: number = properties.sumBy('forecastedCashPosition');\n\n    // check if forecastedCashPosition = 0 to avoid division by zero\n    if (!forecastedCashPosition) {\n      return 0;\n    }\n\n    return (transactions.grossClaimAmount - forecastedCashPosition) / forecastedCashPosition;\n  }\n\n  /**\n   * Get Badge for single property in collection\n   */\n  private getBadge(property: Property, properties: PropertyCollection, transactions: TransactionCollection, depreciations: DepreciationCollection): Badge {\n    // best performance properties could be only from active properties list\n    const activeProperties: PropertyCollection = properties.getActiveProperties();\n    const bestPerformanceGrowthProperty: Property = activeProperties.getBestPerformanceGrowthProperty();\n    const bestPerformanceTaxProperty: Property = activeProperties.getBestPerformanceTaxProperty(\n      transactions, depreciations\n    );\n\n    switch (true) {\n      case !property.isActive:\n        return new Badge('Inactive', BadgeColorEnum.GRAY);\n      case property.id === bestPerformanceTaxProperty.id && property.id === bestPerformanceGrowthProperty.id:\n        return new Badge('Best performance growth & tax', BadgeColorEnum.GOLD);\n      case property.id === bestPerformanceTaxProperty.id:\n        return new Badge('Best performance tax', BadgeColorEnum.GOLD);\n      case property.id === bestPerformanceGrowthProperty.id:\n        return new Badge('Best performance growth', BadgeColorEnum.GREEN);\n      default:\n        return new Badge('Monitoring performance');\n    }\n  }\n}\n"]}
|
package/fesm2015/taxtank-core.js
CHANGED
|
@@ -249,23 +249,25 @@ var AppEventTypeEnum;
|
|
|
249
249
|
AppEventTypeEnum[AppEventTypeEnum["SOLE_DETAILS_UPDATED"] = 49] = "SOLE_DETAILS_UPDATED";
|
|
250
250
|
AppEventTypeEnum[AppEventTypeEnum["SOLE_INVOICE_PUBLISHED"] = 50] = "SOLE_INVOICE_PUBLISHED";
|
|
251
251
|
AppEventTypeEnum[AppEventTypeEnum["TAX_REVIEW_UPDATED"] = 51] = "TAX_REVIEW_UPDATED";
|
|
252
|
-
AppEventTypeEnum[AppEventTypeEnum["
|
|
253
|
-
AppEventTypeEnum[AppEventTypeEnum["
|
|
254
|
-
AppEventTypeEnum[AppEventTypeEnum["
|
|
255
|
-
AppEventTypeEnum[AppEventTypeEnum["
|
|
256
|
-
AppEventTypeEnum[AppEventTypeEnum["
|
|
257
|
-
AppEventTypeEnum[AppEventTypeEnum["
|
|
258
|
-
AppEventTypeEnum[AppEventTypeEnum["
|
|
259
|
-
AppEventTypeEnum[AppEventTypeEnum["
|
|
260
|
-
AppEventTypeEnum[AppEventTypeEnum["
|
|
261
|
-
AppEventTypeEnum[AppEventTypeEnum["
|
|
262
|
-
AppEventTypeEnum[AppEventTypeEnum["
|
|
263
|
-
AppEventTypeEnum[AppEventTypeEnum["
|
|
264
|
-
AppEventTypeEnum[AppEventTypeEnum["
|
|
265
|
-
AppEventTypeEnum[AppEventTypeEnum["
|
|
266
|
-
AppEventTypeEnum[AppEventTypeEnum["
|
|
267
|
-
AppEventTypeEnum[AppEventTypeEnum["
|
|
268
|
-
AppEventTypeEnum[AppEventTypeEnum["
|
|
252
|
+
AppEventTypeEnum[AppEventTypeEnum["TRANSACTION_ALLOCATION_CREATED"] = 52] = "TRANSACTION_ALLOCATION_CREATED";
|
|
253
|
+
AppEventTypeEnum[AppEventTypeEnum["TRANSACTION_ALLOCATION_DELETED"] = 53] = "TRANSACTION_ALLOCATION_DELETED";
|
|
254
|
+
AppEventTypeEnum[AppEventTypeEnum["TRANSACTION_CREATED"] = 54] = "TRANSACTION_CREATED";
|
|
255
|
+
AppEventTypeEnum[AppEventTypeEnum["TRANSACTION_DELETED"] = 55] = "TRANSACTION_DELETED";
|
|
256
|
+
AppEventTypeEnum[AppEventTypeEnum["TRANSACTION_UPDATED"] = 56] = "TRANSACTION_UPDATED";
|
|
257
|
+
AppEventTypeEnum[AppEventTypeEnum["TRANSACTION_UPDATED_WITH_RECEIPT"] = 57] = "TRANSACTION_UPDATED_WITH_RECEIPT";
|
|
258
|
+
AppEventTypeEnum[AppEventTypeEnum["TRANSACTION_UPDATED_WITH_DELETED_RECEIPT"] = 58] = "TRANSACTION_UPDATED_WITH_DELETED_RECEIPT";
|
|
259
|
+
AppEventTypeEnum[AppEventTypeEnum["TRANSACTION_RECEIPT_CREATED"] = 59] = "TRANSACTION_RECEIPT_CREATED";
|
|
260
|
+
AppEventTypeEnum[AppEventTypeEnum["TRANSACTION_RECEIPT_DELETED"] = 60] = "TRANSACTION_RECEIPT_DELETED";
|
|
261
|
+
AppEventTypeEnum[AppEventTypeEnum["TRANSACTIONS_CREATED"] = 61] = "TRANSACTIONS_CREATED";
|
|
262
|
+
AppEventTypeEnum[AppEventTypeEnum["USER_UPDATED"] = 62] = "USER_UPDATED";
|
|
263
|
+
AppEventTypeEnum[AppEventTypeEnum["VEHICLE_CLAIM_UPDATED"] = 63] = "VEHICLE_CLAIM_UPDATED";
|
|
264
|
+
AppEventTypeEnum[AppEventTypeEnum["VEHICLE_CLAIM_CREATED"] = 64] = "VEHICLE_CLAIM_CREATED";
|
|
265
|
+
AppEventTypeEnum[AppEventTypeEnum["VEHICLE_CLAIM_DETAILS_UPDATED"] = 65] = "VEHICLE_CLAIM_DETAILS_UPDATED";
|
|
266
|
+
AppEventTypeEnum[AppEventTypeEnum["VEHICLE_CLAIM_DETAILS_CREATED"] = 66] = "VEHICLE_CLAIM_DETAILS_CREATED";
|
|
267
|
+
AppEventTypeEnum[AppEventTypeEnum["VEHICLE_LOGBOOK_CREATED"] = 67] = "VEHICLE_LOGBOOK_CREATED";
|
|
268
|
+
AppEventTypeEnum[AppEventTypeEnum["VEHICLE_LOGBOOK_UPDATED"] = 68] = "VEHICLE_LOGBOOK_UPDATED";
|
|
269
|
+
AppEventTypeEnum[AppEventTypeEnum["VEHICLE_LOGBOOK_DELETED"] = 69] = "VEHICLE_LOGBOOK_DELETED";
|
|
270
|
+
AppEventTypeEnum[AppEventTypeEnum["VEHICLE_LOGBOOK_BEST_PERIOD_UPDATED"] = 70] = "VEHICLE_LOGBOOK_BEST_PERIOD_UPDATED";
|
|
269
271
|
})(AppEventTypeEnum || (AppEventTypeEnum = {}));
|
|
270
272
|
|
|
271
273
|
class EventDispatcherService {
|
|
@@ -4749,7 +4751,7 @@ class Property extends Property$1 {
|
|
|
4749
4751
|
* https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217415928/Dashboard+Property
|
|
4750
4752
|
*/
|
|
4751
4753
|
getTaxPosition(transactions, depreciations) {
|
|
4752
|
-
return transactions.
|
|
4754
|
+
return transactions.grossClaimAmount - Math.abs(depreciations.claimAmount);
|
|
4753
4755
|
}
|
|
4754
4756
|
}
|
|
4755
4757
|
/**
|
|
@@ -6210,7 +6212,7 @@ class PropertyCategoryMovementCollection extends Collection {
|
|
|
6210
6212
|
getByForecast(property, forecast) {
|
|
6211
6213
|
const financialYear = new FinancialYear(forecast.financialYear);
|
|
6212
6214
|
return this.filterBy('property.id', property.id).filter((movement) => {
|
|
6213
|
-
return movement.fromDate <= financialYear.endDate && movement.toDate >= financialYear.startDate;
|
|
6215
|
+
return movement.fromDate <= financialYear.endDate && !movement.toDate || movement.toDate >= financialYear.startDate;
|
|
6214
6216
|
});
|
|
6215
6217
|
}
|
|
6216
6218
|
hasCategory(categoryId) {
|
|
@@ -6263,26 +6265,18 @@ class TransactionCollection extends ExportableCollection {
|
|
|
6263
6265
|
return sum + transaction.getUnallocatedAmount(allocations.filterBy('transaction.id', transaction.id));
|
|
6264
6266
|
}, 0);
|
|
6265
6267
|
}
|
|
6266
|
-
/**
|
|
6267
|
-
* Get cash position
|
|
6268
|
-
* Cash Position = Income - Expenses
|
|
6269
|
-
* Cash position is equal to Total Amount because income is positive and expense is negative,
|
|
6270
|
-
*/
|
|
6271
|
-
get cashPosition() {
|
|
6272
|
-
return this.grossAmount;
|
|
6273
|
-
}
|
|
6274
6268
|
/**
|
|
6275
6269
|
* get date of the last transaction
|
|
6276
6270
|
*/
|
|
6277
6271
|
getLastTransactionDate() {
|
|
6278
6272
|
return new Date(Math.max.apply(Math, this.items.map((transaction) => transaction.date)));
|
|
6279
6273
|
}
|
|
6280
|
-
/**
|
|
6281
|
-
* Get summary of claim amounts
|
|
6282
|
-
*/
|
|
6283
6274
|
get claimAmount() {
|
|
6284
6275
|
return this.items.reduce((sum, transaction) => sum + transaction.claimAmount, 0);
|
|
6285
6276
|
}
|
|
6277
|
+
get grossClaimAmount() {
|
|
6278
|
+
return this.items.reduce((sum, transaction) => sum + transaction.grossClaimAmount, 0);
|
|
6279
|
+
}
|
|
6286
6280
|
get grossAmount() {
|
|
6287
6281
|
return this.items.reduce((sum, transaction) => sum + transaction.grossAmount, 0);
|
|
6288
6282
|
}
|
|
@@ -10507,6 +10501,9 @@ class SoleInvoiceService extends RestService {
|
|
|
10507
10501
|
this.url = 'sole-invoices';
|
|
10508
10502
|
this.isHydra = true;
|
|
10509
10503
|
}
|
|
10504
|
+
listenEvents() {
|
|
10505
|
+
this.listenAllocations();
|
|
10506
|
+
}
|
|
10510
10507
|
add(invoice) {
|
|
10511
10508
|
return super.add(invoice).pipe(map((newInvoice) => {
|
|
10512
10509
|
// invoice published right away skipping draft status
|
|
@@ -10552,6 +10549,14 @@ class SoleInvoiceService extends RestService {
|
|
|
10552
10549
|
const number = (_b = (_a = last(this.cache)) === null || _a === void 0 ? void 0 : _a.number) !== null && _b !== void 0 ? _b : 0;
|
|
10553
10550
|
return number + 1;
|
|
10554
10551
|
}
|
|
10552
|
+
listenAllocations() {
|
|
10553
|
+
this.eventDispatcherService.on([
|
|
10554
|
+
AppEventTypeEnum.TRANSACTION_ALLOCATION_CREATED,
|
|
10555
|
+
AppEventTypeEnum.TRANSACTION_ALLOCATION_DELETED
|
|
10556
|
+
]).subscribe(() => {
|
|
10557
|
+
this.resetCache();
|
|
10558
|
+
});
|
|
10559
|
+
}
|
|
10555
10560
|
}
|
|
10556
10561
|
SoleInvoiceService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: SoleInvoiceService, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
|
|
10557
10562
|
SoleInvoiceService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: SoleInvoiceService, providedIn: 'root' });
|
|
@@ -11549,6 +11554,25 @@ class TransactionAllocationService extends RestService {
|
|
|
11549
11554
|
add(allocation) {
|
|
11550
11555
|
return this.addBatch([allocation]).pipe(map((newAllocations) => newAllocations[0]));
|
|
11551
11556
|
}
|
|
11557
|
+
addBatch(models, queryParams) {
|
|
11558
|
+
return super.addBatch(models, queryParams)
|
|
11559
|
+
.pipe(map((allocations) => {
|
|
11560
|
+
this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.TRANSACTION_ALLOCATION_CREATED, allocations));
|
|
11561
|
+
return allocations;
|
|
11562
|
+
}));
|
|
11563
|
+
}
|
|
11564
|
+
delete(model) {
|
|
11565
|
+
return super.delete(model)
|
|
11566
|
+
.pipe(map(() => {
|
|
11567
|
+
this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.TRANSACTION_ALLOCATION_DELETED, null));
|
|
11568
|
+
}));
|
|
11569
|
+
}
|
|
11570
|
+
deleteBatch(models) {
|
|
11571
|
+
return super.deleteBatch(models)
|
|
11572
|
+
.pipe(map(() => {
|
|
11573
|
+
this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.TRANSACTION_ALLOCATION_DELETED, null));
|
|
11574
|
+
}));
|
|
11575
|
+
}
|
|
11552
11576
|
/**
|
|
11553
11577
|
* get list of transactions allocations related with passed bank transactions list
|
|
11554
11578
|
*/
|
|
@@ -14293,7 +14317,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
|
|
|
14293
14317
|
class PropertyCalculationService {
|
|
14294
14318
|
getTaxPosition(transactions, depreciations) {
|
|
14295
14319
|
// @TODO hack: math abs added because we have mismatching of real values signs
|
|
14296
|
-
return transactions.
|
|
14320
|
+
return transactions.grossClaimAmount - Math.abs(depreciations.claimAmount);
|
|
14297
14321
|
}
|
|
14298
14322
|
getTaxPosition$(transactions$, depreciations$) {
|
|
14299
14323
|
return combineLatest([
|
|
@@ -14424,7 +14448,7 @@ class PropertyCalculationService {
|
|
|
14424
14448
|
if (!forecastedCashPosition) {
|
|
14425
14449
|
return 0;
|
|
14426
14450
|
}
|
|
14427
|
-
return (transactions.
|
|
14451
|
+
return (transactions.grossClaimAmount - forecastedCashPosition) / forecastedCashPosition;
|
|
14428
14452
|
}
|
|
14429
14453
|
/**
|
|
14430
14454
|
* Get Badge for single property in collection
|
|
@@ -14759,20 +14783,23 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
|
|
|
14759
14783
|
}]
|
|
14760
14784
|
}] });
|
|
14761
14785
|
|
|
14786
|
+
/**
|
|
14787
|
+
* @TODO Alex refactor
|
|
14788
|
+
*/
|
|
14762
14789
|
class SubscriptionService {
|
|
14763
|
-
constructor(http, eventDispatcherService, sseService, environment) {
|
|
14790
|
+
constructor(http, eventDispatcherService, sseService, toastService, environment) {
|
|
14764
14791
|
this.http = http;
|
|
14765
14792
|
this.eventDispatcherService = eventDispatcherService;
|
|
14766
14793
|
this.sseService = sseService;
|
|
14794
|
+
this.toastService = toastService;
|
|
14767
14795
|
this.environment = environment;
|
|
14768
14796
|
this.serviceSubscriptionSubject = new ReplaySubject(1);
|
|
14769
|
-
this.serviceSubscriptionsSubject = new ReplaySubject(1);
|
|
14770
14797
|
this.servicePaymentsSubject = new ReplaySubject(1);
|
|
14771
|
-
this.subscriptionChangeSubject = new BehaviorSubject(null);
|
|
14772
14798
|
this.listenSubscriptions();
|
|
14773
14799
|
}
|
|
14774
14800
|
getSubscription(force = false) {
|
|
14775
|
-
if (
|
|
14801
|
+
if (this._serviceSubscription === undefined || force) {
|
|
14802
|
+
this._serviceSubscription = null;
|
|
14776
14803
|
this.http.get(`${this.environment.apiV2}/subscriptions/last`)
|
|
14777
14804
|
.pipe(map((response) => {
|
|
14778
14805
|
return plainToClass(ServiceSubscription, response);
|
|
@@ -14838,20 +14865,22 @@ class SubscriptionService {
|
|
|
14838
14865
|
this.sseService.on(`serviceSubscriptions`)
|
|
14839
14866
|
.pipe(map((event) => plainToClass(ServiceSubscription, event)))
|
|
14840
14867
|
.subscribe((subscription) => {
|
|
14841
|
-
this.
|
|
14842
|
-
this.
|
|
14868
|
+
this._serviceSubscription = subscription;
|
|
14869
|
+
this.serviceSubscriptionSubject.next(this._serviceSubscription);
|
|
14843
14870
|
this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.SERVICE_SUBSCRIPTION_UPDATED, null));
|
|
14871
|
+
// @TODO move?
|
|
14872
|
+
this.toastService.success('Subscription successfully updated');
|
|
14844
14873
|
});
|
|
14845
14874
|
}
|
|
14846
14875
|
}
|
|
14847
|
-
SubscriptionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: SubscriptionService, deps: [{ token: i1.HttpClient }, { token: EventDispatcherService }, { token: SseService }, { token: 'environment' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
14876
|
+
SubscriptionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: SubscriptionService, deps: [{ token: i1.HttpClient }, { token: EventDispatcherService }, { token: SseService }, { token: ToastService }, { token: 'environment' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
14848
14877
|
SubscriptionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: SubscriptionService, providedIn: 'root' });
|
|
14849
14878
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: SubscriptionService, decorators: [{
|
|
14850
14879
|
type: Injectable,
|
|
14851
14880
|
args: [{
|
|
14852
14881
|
providedIn: 'root'
|
|
14853
14882
|
}]
|
|
14854
|
-
}], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: EventDispatcherService }, { type: SseService }, { type: undefined, decorators: [{
|
|
14883
|
+
}], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: EventDispatcherService }, { type: SseService }, { type: ToastService }, { type: undefined, decorators: [{
|
|
14855
14884
|
type: Inject,
|
|
14856
14885
|
args: ['environment']
|
|
14857
14886
|
}] }]; } });
|