taxtank-core 0.16.13 → 0.17.2
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 +363 -383
- package/bundles/taxtank-core.umd.js.map +1 -1
- package/esm2015/lib/collections/bank-transaction.collection.js +1 -1
- package/esm2015/lib/collections/depreciation.collection.js +2 -2
- package/esm2015/lib/collections/exportable.collection.js +17 -0
- package/esm2015/lib/collections/loan/loan-payment.collection.js +31 -0
- package/esm2015/lib/collections/loan/loan.collection.js +18 -0
- package/esm2015/lib/collections/report/property/property-report-item-transaction.collection.js +1 -1
- package/esm2015/lib/collections/report/vehicle-expense/vehicle-expense.collection.js +1 -1
- package/esm2015/lib/collections/tax-summary/report-item.collection.js +50 -120
- package/esm2015/lib/collections/tax-summary/tax-return-categories.const.js +65 -0
- package/esm2015/lib/collections/transaction/transaction-allocation.collection.js +40 -0
- package/esm2015/lib/collections/transaction/transaction.collection.js +167 -0
- package/esm2015/lib/db/Enums/tax-return-category-list.enum.js +21 -7
- package/esm2015/lib/models/bank/bank-transaction.js +1 -1
- package/esm2015/lib/models/export/export-cell-type.enum.js +10 -0
- package/esm2015/lib/models/export/export-cell.js +6 -0
- package/esm2015/lib/models/export/export-data-table.js +1 -7
- package/esm2015/lib/models/income-source/income-source-chart-data.js +1 -1
- package/esm2015/lib/models/loan/loan-payment.js +2 -24
- package/esm2015/lib/models/logbook/vehicle-claim.js +1 -1
- package/esm2015/lib/models/property/property-equity-chart-data.js +1 -1
- package/esm2015/lib/models/property/property-sale/property-sale.js +10 -1
- package/esm2015/lib/models/report/property/property-report-item-transaction.js +1 -1
- package/esm2015/lib/models/tax-summary/report-item.js +8 -1
- package/esm2015/lib/models/tax-summary/tax-summary.js +28 -9
- package/esm2015/lib/models/transaction/transaction.js +1 -1
- package/esm2015/lib/services/account-setup/account-setup.service.js +2 -2
- package/esm2015/lib/services/bank/bank-account-calculation.service.js +1 -1
- package/esm2015/lib/services/bank/bank-transaction-calculation.service.js +1 -1
- package/esm2015/lib/services/export/export-formatter.service.js +31 -0
- package/esm2015/lib/services/pdf/pdf.service.js +9 -4
- package/esm2015/lib/services/property/property-calculation/property-calculation.service.js +1 -1
- package/esm2015/lib/services/report/property/property-transaction-report.service.js +2 -2
- package/esm2015/lib/services/transaction/transaction-calculation.service.js +2 -2
- package/esm2015/public-api.js +8 -10
- package/fesm2015/taxtank-core.js +301 -286
- package/fesm2015/taxtank-core.js.map +1 -1
- package/lib/collections/bank-transaction.collection.d.ts +1 -1
- package/lib/collections/depreciation.collection.d.ts +1 -1
- package/lib/collections/exportable.collection.d.ts +9 -0
- package/lib/collections/loan/loan-payment.collection.d.ts +7 -0
- package/lib/collections/{loan.collection.d.ts → loan/loan.collection.d.ts} +2 -2
- package/lib/collections/report/property/property-report-item-transaction.collection.d.ts +1 -1
- package/lib/collections/report/vehicle-expense/vehicle-expense.collection.d.ts +1 -1
- package/lib/collections/tax-summary/report-item.collection.d.ts +17 -51
- package/lib/collections/tax-summary/tax-return-categories.const.d.ts +6 -0
- package/lib/collections/{transaction-allocation.collection.d.ts → transaction/transaction-allocation.collection.d.ts} +6 -6
- package/lib/collections/{transaction.collection.d.ts → transaction/transaction.collection.d.ts} +9 -5
- package/lib/db/Enums/tax-return-category-list.enum.d.ts +20 -6
- package/lib/models/bank/bank-transaction.d.ts +1 -1
- package/lib/models/export/export-cell-type.enum.d.ts +8 -0
- package/lib/models/export/export-cell.d.ts +8 -0
- package/lib/models/export/export-data-table.d.ts +3 -2
- package/lib/models/income-source/income-source-chart-data.d.ts +1 -1
- package/lib/models/loan/loan-payment.d.ts +1 -5
- package/lib/models/logbook/vehicle-claim.d.ts +1 -1
- package/lib/models/property/property-equity-chart-data.d.ts +1 -1
- package/lib/models/property/property-sale/property-sale.d.ts +3 -0
- package/lib/models/report/property/property-report-item-transaction.d.ts +1 -1
- package/lib/models/tax-summary/report-item.d.ts +3 -2
- package/lib/models/transaction/transaction.d.ts +1 -1
- package/lib/services/bank/bank-account-calculation.service.d.ts +1 -1
- package/lib/services/bank/bank-transaction-calculation.service.d.ts +1 -1
- package/lib/services/export/export-formatter.service.d.ts +11 -0
- package/lib/services/pdf/pdf.service.d.ts +3 -0
- package/lib/services/property/property-calculation/property-calculation.service.d.ts +2 -2
- package/lib/services/report/property/property-transaction-report.service.d.ts +1 -1
- package/lib/services/transaction/transaction-calculation.service.d.ts +2 -2
- package/package.json +1 -1
- package/public-api.d.ts +7 -9
- package/esm2015/lib/collections/loan.collection.js +0 -18
- package/esm2015/lib/collections/transaction-allocation.collection.js +0 -40
- package/esm2015/lib/collections/transaction.collection.js +0 -143
- package/esm2015/lib/interfaces/exportable.interface.js +0 -2
- package/esm2015/lib/services/data-table/data-table.service.js +0 -47
- package/esm2015/lib/services/property/property-holding-costs/property-holding-costs.service.js +0 -53
- package/lib/interfaces/exportable.interface.d.ts +0 -9
- package/lib/services/data-table/data-table.service.d.ts +0 -19
- package/lib/services/property/property-holding-costs/property-holding-costs.service.d.ts +0 -24
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
import { TankTypeEnum } from '../../db/Enums/tank-type.enum';
|
|
2
|
+
import { ExportCell } from '../../models/export/export-cell';
|
|
3
|
+
import { plainToClass } from 'class-transformer';
|
|
4
|
+
import { ExportCellTypeEnum } from '../../models/export/export-cell-type.enum';
|
|
5
|
+
import { ExportableCollection } from '../exportable.collection';
|
|
6
|
+
/**
|
|
7
|
+
* Collection of transactions
|
|
8
|
+
*/
|
|
9
|
+
export class TransactionCollection extends ExportableCollection {
|
|
10
|
+
/**
|
|
11
|
+
* Get total amount of all transactions in the collection
|
|
12
|
+
*/
|
|
13
|
+
get amount() {
|
|
14
|
+
return +this.items.reduce((sum, transaction) => sum + transaction.getNetAmount(), 0).toFixed(2);
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Difference between allocated amount and total amount
|
|
18
|
+
*/
|
|
19
|
+
getUnallocatedAmount(allocations) {
|
|
20
|
+
return +(this.amount - allocations.getByTransactionsIds(this.getIds()).amount).toFixed(2);
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Get cash position
|
|
24
|
+
* Cash Position = Income - Expenses
|
|
25
|
+
* Cash position is equal to Total Amount because income is positive and expense is negative,
|
|
26
|
+
*/
|
|
27
|
+
get cashPosition() {
|
|
28
|
+
return this.claimAmount;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* get date of the last transaction
|
|
32
|
+
*/
|
|
33
|
+
getLastTransactionDate() {
|
|
34
|
+
return new Date(Math.max.apply(Math, this.items.map((transaction) => transaction.date)));
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Get summary of claim amounts
|
|
38
|
+
*/
|
|
39
|
+
get claimAmount() {
|
|
40
|
+
return this.items.reduce((sum, transaction) => sum + transaction.claimAmount, 0);
|
|
41
|
+
}
|
|
42
|
+
get grossAmount() {
|
|
43
|
+
return +this.items.reduce((sum, transaction) => sum + transaction.amount, 0).toFixed(2);
|
|
44
|
+
}
|
|
45
|
+
getByChartAccountsCategories(categories) {
|
|
46
|
+
return new TransactionCollection(this.items.filter((transaction) => categories.includes(transaction.chartAccounts.category)));
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Get transactions by month
|
|
50
|
+
* @param monthIndex by which desired month should be taken
|
|
51
|
+
*/
|
|
52
|
+
getByMonth(monthIndex) {
|
|
53
|
+
return new TransactionCollection(this.items.filter((transaction) => transaction.date.getMonth() === monthIndex));
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* get list of transactions filtered by chart accounts id
|
|
57
|
+
* @param chartAccountsId chart accounts id for filtering
|
|
58
|
+
*/
|
|
59
|
+
getByChartAccountsId(chartAccountsId) {
|
|
60
|
+
return this.items.filter((transaction) => transaction.chartAccounts.id === chartAccountsId);
|
|
61
|
+
}
|
|
62
|
+
getIncomeTransactions() {
|
|
63
|
+
return new TransactionCollection(this.items.filter((transaction) => transaction.isIncome()));
|
|
64
|
+
}
|
|
65
|
+
get claimIncome() {
|
|
66
|
+
return this.getIncomeTransactions().claimAmount;
|
|
67
|
+
}
|
|
68
|
+
getExpenseTransactions() {
|
|
69
|
+
return new TransactionCollection(this.items.filter((transaction) => transaction.isExpense() && !transaction.isInterest()));
|
|
70
|
+
}
|
|
71
|
+
get claimExpense() {
|
|
72
|
+
return this.getExpenseTransactions().claimAmount;
|
|
73
|
+
}
|
|
74
|
+
getInterestTransactions() {
|
|
75
|
+
return new TransactionCollection(this.items.filter((transaction) => transaction.isInterest()));
|
|
76
|
+
}
|
|
77
|
+
get claimInterest() {
|
|
78
|
+
return this.getInterestTransactions().claimAmount;
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Get collection of transactions and properties filtered by properties ids
|
|
82
|
+
* @param ids Ids of properties for filter
|
|
83
|
+
*/
|
|
84
|
+
getByPropertiesIds(ids) {
|
|
85
|
+
return new TransactionCollection(this.items.filter((transaction) => {
|
|
86
|
+
var _a;
|
|
87
|
+
return ids.includes((_a = transaction.property) === null || _a === void 0 ? void 0 : _a.id);
|
|
88
|
+
}));
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Get new collection filtered by income source id
|
|
92
|
+
* @param id id of income source for filter
|
|
93
|
+
*/
|
|
94
|
+
getByIncomeSourceId(id) {
|
|
95
|
+
return new TransactionCollection(this.items.filter((transaction) => { var _a; return ((_a = transaction.incomeSource) === null || _a === void 0 ? void 0 : _a.id) === id; }));
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Get new collection filtered by chart accounts category
|
|
99
|
+
* @param category Chart accounts category value
|
|
100
|
+
*/
|
|
101
|
+
getByChartAccountsCategory(category) {
|
|
102
|
+
return new TransactionCollection(this.items.filter((transaction) => transaction.chartAccounts.category === category));
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* Get new collection of property transactions
|
|
106
|
+
*/
|
|
107
|
+
getPropertyTransactions() {
|
|
108
|
+
return new TransactionCollection(this.items.filter((transaction) => transaction.isPropertyTank()));
|
|
109
|
+
}
|
|
110
|
+
getDebitTransactions() {
|
|
111
|
+
return new TransactionCollection(this.items.filter((transaction) => transaction.isDebit()));
|
|
112
|
+
}
|
|
113
|
+
getCreditTransactions() {
|
|
114
|
+
return new TransactionCollection(this.items.filter((transaction) => transaction.isCredit()));
|
|
115
|
+
}
|
|
116
|
+
getByAllocations(allocations) {
|
|
117
|
+
return new TransactionCollection(this.items.filter((transaction) => allocations.hasTransaction(transaction)));
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
* Get transactions related to Vehicle category
|
|
121
|
+
*/
|
|
122
|
+
getVehicleTransactions() {
|
|
123
|
+
return this.create(this.items.filter((transaction) => {
|
|
124
|
+
return transaction.isVehicleTransaction();
|
|
125
|
+
}));
|
|
126
|
+
}
|
|
127
|
+
/**
|
|
128
|
+
* Get new transaction collection filtered by tank type
|
|
129
|
+
*/
|
|
130
|
+
getByTankType(tankType) {
|
|
131
|
+
return this.create(this.items.filter((transaction) => {
|
|
132
|
+
switch (tankType) {
|
|
133
|
+
case TankTypeEnum.PROPERTY:
|
|
134
|
+
return transaction.isPropertyTank();
|
|
135
|
+
case TankTypeEnum.WORK:
|
|
136
|
+
return transaction.isWorkTank();
|
|
137
|
+
case TankTypeEnum.SOLE:
|
|
138
|
+
return transaction.isSoleTank();
|
|
139
|
+
// Transaction may be not related to any tank type (personal)
|
|
140
|
+
default:
|
|
141
|
+
return false;
|
|
142
|
+
}
|
|
143
|
+
}));
|
|
144
|
+
}
|
|
145
|
+
getExportHeader() {
|
|
146
|
+
return ['Date', 'Description', 'Debit', 'Credit'];
|
|
147
|
+
}
|
|
148
|
+
getExportFooter() {
|
|
149
|
+
return [
|
|
150
|
+
plainToClass(ExportCell, { value: 'Total', type: ExportCellTypeEnum.STRING }),
|
|
151
|
+
plainToClass(ExportCell, { value: '', type: ExportCellTypeEnum.STRING }),
|
|
152
|
+
plainToClass(ExportCell, { value: this.sumBy('debit'), type: ExportCellTypeEnum.CURRENCY }),
|
|
153
|
+
plainToClass(ExportCell, { value: this.sumBy('credit'), type: ExportCellTypeEnum.CURRENCY })
|
|
154
|
+
];
|
|
155
|
+
}
|
|
156
|
+
getExportBody() {
|
|
157
|
+
return this.items.map((transaction) => {
|
|
158
|
+
return [
|
|
159
|
+
plainToClass(ExportCell, { value: transaction.date, type: ExportCellTypeEnum.DATE }),
|
|
160
|
+
plainToClass(ExportCell, { value: transaction.description, type: ExportCellTypeEnum.STRING }),
|
|
161
|
+
plainToClass(ExportCell, { value: transaction.debit, type: ExportCellTypeEnum.CURRENCY }),
|
|
162
|
+
plainToClass(ExportCell, { value: transaction.credit, type: ExportCellTypeEnum.CURRENCY })
|
|
163
|
+
];
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.collection.js","sourceRoot":"","sources":["../../../../../../projects/tt-core/src/lib/collections/transaction/transaction.collection.ts"],"names":[],"mappings":"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","sourcesContent":["import { Transaction } from '../../models/transaction/transaction';\nimport { TransactionAllocationCollection } from './transaction-allocation.collection';\nimport { ChartAccountsCategoryEnum } from '../../db/Enums/chart-accounts-category.enum';\nimport { TankTypeEnum } from '../../db/Enums/tank-type.enum';\nimport { ExportCell } from '../../models/export/export-cell';\nimport { plainToClass } from 'class-transformer';\nimport { ExportCellTypeEnum } from '../../models/export/export-cell-type.enum';\nimport { ExportableCollection } from '../exportable.collection';\n\n/**\n * Collection of transactions\n */\nexport class TransactionCollection extends ExportableCollection<Transaction> {\n  /**\n   * Get total amount of all transactions in the collection\n   */\n  get amount(): number {\n    return +this.items.reduce((sum: number, transaction: Transaction) => sum + transaction.getNetAmount(), 0).toFixed(2);\n  }\n\n  /**\n   * Difference between allocated amount and total amount\n   */\n  getUnallocatedAmount(allocations: TransactionAllocationCollection): number {\n    return +(this.amount - allocations.getByTransactionsIds(this.getIds()).amount).toFixed(2);\n  }\n\n  /**\n   * Get cash position\n   * Cash Position = Income - Expenses\n   * Cash position is equal to Total Amount because income is positive and expense is negative,\n   */\n  get cashPosition(): number {\n    return this.claimAmount;\n  }\n\n  /**\n   * get date of the last transaction\n   */\n  getLastTransactionDate(): Date {\n    return new Date(Math.max.apply(Math, this.items.map((transaction: Transaction) => transaction.date)));\n  }\n\n  /**\n   * Get summary of claim amounts\n   */\n  get claimAmount(): number {\n    return this.items.reduce((sum: number, transaction: Transaction) => sum + transaction.claimAmount, 0);\n  }\n\n  get grossAmount(): number {\n    return +this.items.reduce((sum: number, transaction: Transaction) => sum + transaction.amount, 0).toFixed(2);\n  }\n\n  getByChartAccountsCategories(categories: ChartAccountsCategoryEnum[]): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => categories.includes(transaction.chartAccounts.category))\n    );\n  }\n\n  /**\n   * Get transactions by month\n   * @param monthIndex by which desired month should be taken\n   */\n  getByMonth(monthIndex: number): TransactionCollection {\n    return new TransactionCollection(this.items.filter((transaction: Transaction): boolean =>\n      transaction.date.getMonth() === monthIndex\n    ));\n  }\n\n  /**\n   * get list of transactions filtered by chart accounts id\n   * @param chartAccountsId chart accounts id for filtering\n   */\n  getByChartAccountsId(chartAccountsId: number): Transaction[] {\n    return this.items.filter((transaction: Transaction): boolean => transaction.chartAccounts.id === chartAccountsId);\n  }\n\n  getIncomeTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isIncome())\n    );\n  }\n\n  get claimIncome(): number {\n    return this.getIncomeTransactions().claimAmount;\n  }\n\n  getExpenseTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isExpense() && !transaction.isInterest())\n    );\n  }\n\n  get claimExpense(): number {\n    return this.getExpenseTransactions().claimAmount;\n  }\n\n  getInterestTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isInterest())\n    );\n  }\n\n  get claimInterest(): number {\n    return this.getInterestTransactions().claimAmount;\n  }\n\n  /**\n   * Get collection of transactions and properties filtered by properties ids\n   * @param ids Ids of properties for filter\n   */\n  getByPropertiesIds(ids: number[]): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => {\n        return ids.includes(transaction.property?.id);\n      })\n    );\n  }\n\n  /**\n   * Get new collection filtered by income source id\n   * @param id id of income source for filter\n   */\n  getByIncomeSourceId(id: number): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.incomeSource?.id === id)\n    );\n  }\n\n  /**\n   * Get new collection filtered by chart accounts category\n   * @param category Chart accounts category value\n   */\n  getByChartAccountsCategory(category: ChartAccountsCategoryEnum): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.chartAccounts.category === category)\n    );\n  }\n\n  /**\n   * Get new collection of property transactions\n   */\n  getPropertyTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isPropertyTank())\n    );\n  }\n\n  getDebitTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isDebit())\n    );\n  }\n\n  getCreditTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isCredit())\n    );\n  }\n\n  getByAllocations(allocations: TransactionAllocationCollection): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => allocations.hasTransaction(transaction))\n    );\n  }\n\n  /**\n   * Get transactions related to Vehicle category\n   */\n  getVehicleTransactions(): this {\n    return this.create(\n      this.items.filter((transaction: Transaction): boolean => {\n        return transaction.isVehicleTransaction();\n      })\n    );\n  }\n\n  /**\n   * Get new transaction collection filtered by tank type\n   */\n  getByTankType(tankType: TankTypeEnum): this {\n    return this.create(\n      this.items.filter((transaction: Transaction): boolean => {\n        switch (tankType) {\n          case TankTypeEnum.PROPERTY:\n            return transaction.isPropertyTank();\n          case TankTypeEnum.WORK:\n            return transaction.isWorkTank();\n          case TankTypeEnum.SOLE:\n            return transaction.isSoleTank();\n          // Transaction may be not related to any tank type (personal)\n          default:\n            return false;\n        }\n      })\n    );\n  }\n\n  getExportHeader(): string[] {\n    return ['Date', 'Description', 'Debit', 'Credit'];\n  }\n\n  getExportFooter(): ExportCell[] {\n    return [\n      plainToClass(ExportCell, {value: 'Total', type: ExportCellTypeEnum.STRING}),\n      plainToClass(ExportCell, {value: '', type: ExportCellTypeEnum.STRING}),\n      plainToClass(ExportCell, {value: this.sumBy('debit'), type: ExportCellTypeEnum.CURRENCY}),\n      plainToClass(ExportCell, {value: this.sumBy('credit'), type: ExportCellTypeEnum.CURRENCY})\n    ];\n  }\n\n  getExportBody(): ExportCell[][] {\n    return this.items.map((transaction: Transaction) => {\n      return [\n        plainToClass(ExportCell, {value: transaction.date, type: ExportCellTypeEnum.DATE}),\n        plainToClass(ExportCell, {value: transaction.description, type: ExportCellTypeEnum.STRING}),\n        plainToClass(ExportCell, {value: transaction.debit, type: ExportCellTypeEnum.CURRENCY}),\n        plainToClass(ExportCell, {value: transaction.credit, type: ExportCellTypeEnum.CURRENCY})\n      ];\n    });\n  }\n}\n"]}
|
|
@@ -1,28 +1,42 @@
|
|
|
1
1
|
export var TaxReturnCategoryListEnum;
|
|
2
2
|
(function (TaxReturnCategoryListEnum) {
|
|
3
3
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["SALARY"] = 1] = "SALARY";
|
|
4
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["ALLOWANCES_EARNINGS_TIPS_DIRECTOR_FEES"] = 30] = "ALLOWANCES_EARNINGS_TIPS_DIRECTOR_FEES";
|
|
5
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["EMPLOYER_LUMP_SUM_PAYMENTS"] = 31] = "EMPLOYER_LUMP_SUM_PAYMENTS";
|
|
6
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["ETP"] = 32] = "ETP";
|
|
7
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["GOVERNMENT_ALLOWANCES"] = 2] = "GOVERNMENT_ALLOWANCES";
|
|
8
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["GOVERNMENT_PENSIONS"] = 33] = "GOVERNMENT_PENSIONS";
|
|
9
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["ANNUITIES_SUPER_INCOME_STREAMS"] = 3] = "ANNUITIES_SUPER_INCOME_STREAMS";
|
|
10
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["SUPERANNUATION_LUMP_SUM_PAYMENTS"] = 34] = "SUPERANNUATION_LUMP_SUM_PAYMENTS";
|
|
11
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["ATTRIBUTED_PSI_INCOME"] = 4] = "ATTRIBUTED_PSI_INCOME";
|
|
4
12
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["WORK_EXPENSES"] = 7] = "WORK_EXPENSES";
|
|
5
13
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["GROSS_RENT"] = 8] = "GROSS_RENT";
|
|
14
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["OTHER_RENTAL_DEDUCTIONS"] = 12] = "OTHER_RENTAL_DEDUCTIONS";
|
|
6
15
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["INTEREST_DEDUCTIONS"] = 9] = "INTEREST_DEDUCTIONS";
|
|
7
16
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["CAPITAL_WORKS"] = 10] = "CAPITAL_WORKS";
|
|
8
17
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["DEPRECIATION"] = 11] = "DEPRECIATION";
|
|
9
|
-
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["
|
|
10
|
-
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["
|
|
18
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["GROSS_INTEREST"] = 5] = "GROSS_INTEREST";
|
|
19
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["DIVIDENDS"] = 6] = "DIVIDENDS";
|
|
20
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["SHARE_SCHEMES"] = 35] = "SHARE_SCHEMES";
|
|
11
21
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["PARTNERSHIPS_TRUSTS"] = 13] = "PARTNERSHIPS_TRUSTS";
|
|
12
|
-
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["
|
|
22
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["PSI_SBE_INCOME"] = 14] = "PSI_SBE_INCOME";
|
|
23
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["SOLE_TRADER_BUSINESS_INCOME"] = 38] = "SOLE_TRADER_BUSINESS_INCOME";
|
|
13
24
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["CAPITAL_GAINS"] = 15] = "CAPITAL_GAINS";
|
|
14
25
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["FOREIGN_SOURCE_INCOME"] = 16] = "FOREIGN_SOURCE_INCOME";
|
|
15
|
-
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["
|
|
26
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["BONUSES_FROM_LIFE_INSURANCE"] = 17] = "BONUSES_FROM_LIFE_INSURANCE";
|
|
27
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["FORESTRY_MANAGED_INVESTMENT_SCHEMES"] = 39] = "FORESTRY_MANAGED_INVESTMENT_SCHEMES";
|
|
28
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["OTHER_INCOME"] = 40] = "OTHER_INCOME";
|
|
29
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["TAX_CREDITS"] = 23] = "TAX_CREDITS";
|
|
16
30
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["OTHER_DEDUCTIONS"] = 18] = "OTHER_DEDUCTIONS";
|
|
31
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["TAX_OFFSETS"] = 27] = "TAX_OFFSETS";
|
|
32
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["BORROWING_EXPENSES"] = 29] = "BORROWING_EXPENSES";
|
|
17
33
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["GROSS_TAX_PAYABLE"] = 19] = "GROSS_TAX_PAYABLE";
|
|
18
34
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["TAX_ON_TAXABLE_INCOME"] = 20] = "TAX_ON_TAXABLE_INCOME";
|
|
19
35
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["MEDICARE"] = 21] = "MEDICARE";
|
|
20
36
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["STUDENT_LOAN_REPAYMENT"] = 22] = "STUDENT_LOAN_REPAYMENT";
|
|
21
|
-
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["TAX_CREDITS"] = 23] = "TAX_CREDITS";
|
|
22
37
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["TAX_WITHHELD"] = 24] = "TAX_WITHHELD";
|
|
23
38
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["TAX_INSTALMENTS"] = 25] = "TAX_INSTALMENTS";
|
|
24
39
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["FRANKING_CREDITS"] = 26] = "FRANKING_CREDITS";
|
|
25
|
-
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["TAX_OFFSETS"] = 27] = "TAX_OFFSETS";
|
|
26
40
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["TAX_PAYABLE"] = 28] = "TAX_PAYABLE";
|
|
27
41
|
})(TaxReturnCategoryListEnum || (TaxReturnCategoryListEnum = {}));
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGF4LXJldHVybi1jYXRlZ29yeS1saXN0LmVudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dC1jb3JlL3NyYy9saWIvZGIvRW51bXMvdGF4LXJldHVybi1jYXRlZ29yeS1saXN0LmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVkseUJBaURYO0FBakRELFdBQVkseUJBQXlCO0lBQ25DLDZFQUFVLENBQUE7SUFDViw4SUFBMkMsQ0FBQTtJQUMzQyxzSEFBK0IsQ0FBQTtJQUMvQix3RUFBUSxDQUFBO0lBQ1IsMkdBQXlCLENBQUE7SUFDekIsd0dBQXdCLENBQUE7SUFDeEIsNkhBQWtDLENBQUE7SUFDbEMsa0lBQXFDLENBQUE7SUFDckMsMkdBQXlCLENBQUE7SUFFekIsMkZBQWlCLENBQUE7SUFFakIscUZBQWMsQ0FBQTtJQUVkLGdIQUE0QixDQUFBO0lBRTVCLHVHQUF1QixDQUFBO0lBRXZCLDRGQUFrQixDQUFBO0lBQ2xCLDBGQUFpQixDQUFBO0lBRWpCLDZGQUFrQixDQUFBO0lBQ2xCLG1GQUFhLENBQUE7SUFDYiw0RkFBa0IsQ0FBQTtJQUNsQix3R0FBd0IsQ0FBQTtJQUN4Qiw4RkFBbUIsQ0FBQTtJQUNuQix3SEFBZ0MsQ0FBQTtJQUNoQyw0RkFBa0IsQ0FBQTtJQUNsQiw0R0FBMEIsQ0FBQTtJQUMxQix3SEFBZ0MsQ0FBQTtJQUNoQyx3SUFBd0MsQ0FBQTtJQUN4QywwRkFBaUIsQ0FBQTtJQUVqQix3RkFBZ0IsQ0FBQTtJQUVoQixrR0FBcUIsQ0FBQTtJQUVyQix3RkFBZ0IsQ0FBQTtJQUVoQixzR0FBdUIsQ0FBQTtJQUN2QixvR0FBc0IsQ0FBQTtJQUN0Qiw0R0FBMEIsQ0FBQTtJQUMxQixrRkFBYSxDQUFBO0lBQ2IsOEdBQTJCLENBQUE7SUFDM0IsMEZBQWlCLENBQUE7SUFDakIsZ0dBQW9CLENBQUE7SUFDcEIsa0dBQXFCLENBQUE7SUFDckIsd0ZBQWdCLENBQUE7QUFDbEIsQ0FBQyxFQWpEVyx5QkFBeUIsS0FBekIseUJBQXlCLFFBaURwQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIFRheFJldHVybkNhdGVnb3J5TGlzdEVudW0ge1xuICBTQUxBUlkgPSAxLFxuICBBTExPV0FOQ0VTX0VBUk5JTkdTX1RJUFNfRElSRUNUT1JfRkVFUyA9IDMwLFxuICBFTVBMT1lFUl9MVU1QX1NVTV9QQVlNRU5UUyA9IDMxLFxuICBFVFAgPSAzMixcbiAgR09WRVJOTUVOVF9BTExPV0FOQ0VTID0gMixcbiAgR09WRVJOTUVOVF9QRU5TSU9OUyA9IDMzLFxuICBBTk5VSVRJRVNfU1VQRVJfSU5DT01FX1NUUkVBTVMgPSAzLFxuICBTVVBFUkFOTlVBVElPTl9MVU1QX1NVTV9QQVlNRU5UUyA9IDM0LFxuICBBVFRSSUJVVEVEX1BTSV9JTkNPTUUgPSA0LFxuXG4gIFdPUktfRVhQRU5TRVMgPSA3LFxuXG4gIEdST1NTX1JFTlQgPSA4LFxuXG4gIE9USEVSX1JFTlRBTF9ERURVQ1RJT05TID0gMTIsXG5cbiAgSU5URVJFU1RfREVEVUNUSU9OUyA9IDksXG5cbiAgQ0FQSVRBTF9XT1JLUyA9IDEwLFxuICBERVBSRUNJQVRJT04gPSAxMSxcblxuICBHUk9TU19JTlRFUkVTVCA9IDUsXG4gIERJVklERU5EUyA9IDYsXG4gIFNIQVJFX1NDSEVNRVMgPSAzNSxcbiAgUEFSVE5FUlNISVBTX1RSVVNUUyA9IDEzLFxuICBQU0lfU0JFX0lOQ09NRSA9IDE0LFxuICBTT0xFX1RSQURFUl9CVVNJTkVTU19JTkNPTUUgPSAzOCxcbiAgQ0FQSVRBTF9HQUlOUyA9IDE1LFxuICBGT1JFSUdOX1NPVVJDRV9JTkNPTUUgPSAxNixcbiAgQk9OVVNFU19GUk9NX0xJRkVfSU5TVVJBTkNFID0gMTcsXG4gIEZPUkVTVFJZX01BTkFHRURfSU5WRVNUTUVOVF9TQ0hFTUVTID0gMzksXG4gIE9USEVSX0lOQ09NRSA9IDQwLFxuXG4gIFRBWF9DUkVESVRTID0gMjMsXG5cbiAgT1RIRVJfREVEVUNUSU9OUyA9IDE4LFxuXG4gIFRBWF9PRkZTRVRTID0gMjcsXG5cbiAgQk9SUk9XSU5HX0VYUEVOU0VTID0gMjksXG4gIEdST1NTX1RBWF9QQVlBQkxFID0gMTksXG4gIFRBWF9PTl9UQVhBQkxFX0lOQ09NRSA9IDIwLFxuICBNRURJQ0FSRSA9IDIxLFxuICBTVFVERU5UX0xPQU5fUkVQQVlNRU5UID0gMjIsXG4gIFRBWF9XSVRISEVMRCA9IDI0LFxuICBUQVhfSU5TVEFMTUVOVFMgPSAyNSxcbiAgRlJBTktJTkdfQ1JFRElUUyA9IDI2LFxuICBUQVhfUEFZQUJMRSA9IDI4LFxufVxuIl19
|
|
@@ -64,4 +64,4 @@ export class BankTransaction extends BankTransactionBase {
|
|
|
64
64
|
__decorate([
|
|
65
65
|
Type(() => Date)
|
|
66
66
|
], BankTransaction.prototype, "date", void 0);
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFuay10cmFuc2FjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3R0LWNvcmUvc3JjL2xpYi9tb2RlbHMvYmFuay9iYW5rLXRyYW5zYWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsZUFBZSxJQUFJLG1CQUFtQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDL0YsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDcEYsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFDL0UsT0FBTyxFQUFFLFlBQVksRUFBRSxJQUFJLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUV2RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFHekQsTUFBTSxPQUFPLGVBQWdCLFNBQVEsbUJBQW1CO0lBQXhEOztRQUNFLDhDQUE4QztRQUM5QyxvQkFBZSxHQUFXLENBQUMsQ0FBQztRQUM1QixzQkFBaUIsR0FBVyxDQUFDLENBQUM7SUE4RGhDLENBQUM7SUF2REM7O09BRUc7SUFDSCxJQUFJLGFBQWE7UUFDZixPQUFPLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDO0lBQ3hFLENBQUM7SUFFRDs7T0FFRztJQUNILE9BQU87UUFDTCxPQUFPLElBQUksQ0FBQyxJQUFJLEtBQUssdUJBQXVCLENBQUMsS0FBSyxDQUFDO0lBQ3JELENBQUM7SUFFRDs7T0FFRztJQUNILFFBQVE7UUFDTixPQUFPLElBQUksQ0FBQyxJQUFJLEtBQUssdUJBQXVCLENBQUMsTUFBTSxDQUFDO0lBQ3RELENBQUM7SUFFRDs7T0FFRztJQUNILGFBQWE7UUFDWCxPQUFPLFlBQVksQ0FBQyxXQUFXLEVBQUU7WUFDL0IsTUFBTSxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO1lBQy9CLFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVztZQUM3QixJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUk7WUFDZixNQUFNLEVBQUUscUJBQXFCLENBQUMsZ0JBQWdCO1lBQzlDLFNBQVMsRUFBRSxJQUFJLENBQUMsU0FBUztZQUN6QixJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUk7U0FDaEIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVEOztPQUVHO0lBQ0gsV0FBVyxDQUFDLFdBQTRDO1FBQ3RELE9BQU8sSUFBSSxDQUFDLE1BQU0sS0FBSyxJQUFJLENBQUMsa0JBQWtCLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDOUQsQ0FBQztJQUVEOztPQUVHO0lBQ0gsa0JBQWtCLENBQUMsV0FBNEM7UUFDN0QsT0FBTyxXQUFXLENBQUMsd0JBQXdCLENBQUMsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUM7SUFDaEUsQ0FBQztJQUVEOztPQUVHO0lBQ0gsb0JBQW9CLENBQUMsV0FBNEM7UUFDL0QsT0FBTyxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUM1RCxDQUFDO0NBQ0Y7QUF6REM7SUFEQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDOzZDQUNOIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFua1RyYW5zYWN0aW9uIGFzIEJhbmtUcmFuc2FjdGlvbkJhc2UgfSBmcm9tICcuLi8uLi9kYi9Nb2RlbHMvYmFuay9iYW5rLXRyYW5zYWN0aW9uJztcbmltcG9ydCB7IEJhbmtUcmFuc2FjdGlvblR5cGVFbnVtIH0gZnJvbSAnLi4vLi4vZGIvRW51bXMvYmFuay10cmFuc2FjdGlvbi10eXBlLmVudW0nO1xuaW1wb3J0IHsgVHJhbnNhY3Rpb25Tb3VyY2VFbnVtIH0gZnJvbSAnLi4vLi4vZGIvRW51bXMvdHJhbnNhY3Rpb24tc291cmNlLmVudW0nO1xuaW1wb3J0IHsgcGxhaW5Ub0NsYXNzLCBUeXBlIH0gZnJvbSAnY2xhc3MtdHJhbnNmb3JtZXInO1xuaW1wb3J0IHsgVHJhbnNhY3Rpb25PcGVyYXRpb25FbnVtIH0gZnJvbSAnLi4vLi4vZGIvRW51bXMvdHJhbnNhY3Rpb24tb3BlcmF0aW9uLmVudW0nO1xuaW1wb3J0IHsgVHJhbnNhY3Rpb24gfSBmcm9tICcuLi90cmFuc2FjdGlvbi90cmFuc2FjdGlvbic7XG5pbXBvcnQgeyBUcmFuc2FjdGlvbkFsbG9jYXRpb25Db2xsZWN0aW9uIH0gZnJvbSAnLi4vLi4vY29sbGVjdGlvbnMvdHJhbnNhY3Rpb24vdHJhbnNhY3Rpb24tYWxsb2NhdGlvbi5jb2xsZWN0aW9uJztcblxuZXhwb3J0IGNsYXNzIEJhbmtUcmFuc2FjdGlvbiBleHRlbmRzIEJhbmtUcmFuc2FjdGlvbkJhc2Uge1xuICAvLyBhbGxvY2F0ZWQgbW9uZXkgYW1vdW50IGZvciBiYW5rIHRyYW5zYWN0aW9uXG4gIGFsbG9jYXRlZEFtb3VudDogbnVtYmVyID0gMDtcbiAgdW5hbGxvY2F0ZWRBbW91bnQ6IG51bWJlciA9IDA7XG5cbiAgb3BlcmF0aW9uOiBUcmFuc2FjdGlvbk9wZXJhdGlvbkVudW07XG5cbiAgQFR5cGUoKCkgPT4gRGF0ZSlcbiAgZGF0ZTogRGF0ZTtcblxuICAvKipcbiAgICogZ2V0IGFsbG9jYXRlZCBhbW91bnQgdmFsdWUgYnV0IHdpdGggKy8tIHNpZ25cbiAgICovXG4gIGdldCBiYWxhbmNlQW1vdW50KCk6IG51bWJlciB7XG4gICAgcmV0dXJuIHRoaXMuaXNDcmVkaXQoKSA/IHRoaXMuYWxsb2NhdGVkQW1vdW50IDogLXRoaXMuYWxsb2NhdGVkQW1vdW50O1xuICB9XG5cbiAgLyoqXG4gICAqIGNoZWNrIGlmIGJhbmsgdHJhbnNhY3Rpb24gaXMgZGViaXRcbiAgICovXG4gIGlzRGViaXQoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMudHlwZSA9PT0gQmFua1RyYW5zYWN0aW9uVHlwZUVudW0uREVCSVQ7XG4gIH1cblxuICAvKipcbiAgICogY2hlY2sgaWYgYmFuayB0cmFuc2FjdGlvbiBpcyBjcmVkaXRcbiAgICovXG4gIGlzQ3JlZGl0KCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLnR5cGUgPT09IEJhbmtUcmFuc2FjdGlvblR5cGVFbnVtLkNSRURJVDtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGUgVHJhbnNhY3Rpb24gaW5zdGFuY2UgYmFzZWQgb24gQmFuayBUcmFuc2FjdGlvblxuICAgKi9cbiAgdG9UcmFuc2FjdGlvbigpOiBUcmFuc2FjdGlvbiB7XG4gICAgcmV0dXJuIHBsYWluVG9DbGFzcyhUcmFuc2FjdGlvbiwge1xuICAgICAgYW1vdW50OiArdGhpcy5hbW91bnQudG9GaXhlZCgyKSxcbiAgICAgIGRlc2NyaXB0aW9uOiB0aGlzLmRlc2NyaXB0aW9uLFxuICAgICAgZGF0ZTogdGhpcy5kYXRlLFxuICAgICAgc291cmNlOiBUcmFuc2FjdGlvblNvdXJjZUVudW0uQkFOS19UUkFOU0FDVElPTixcbiAgICAgIG9wZXJhdGlvbjogdGhpcy5vcGVyYXRpb24sXG4gICAgICB0eXBlOiB0aGlzLnR5cGUsXG4gICAgfSk7XG4gIH1cblxuICAvKipcbiAgICogQ2hlY2sgaWYgYmFuayB0cmFuc2FjdGlvbiBpcyBjb21wbGV0ZWx5IGFsbG9jYXRlZFxuICAgKi9cbiAgaXNBbGxvY2F0ZWQoYWxsb2NhdGlvbnM6IFRyYW5zYWN0aW9uQWxsb2NhdGlvbkNvbGxlY3Rpb24pOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5hbW91bnQgPT09IHRoaXMuZ2V0QWxsb2NhdGVkQW1vdW50KGFsbG9jYXRpb25zKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgYmFuayB0cmFuc2FjdGlvbiBhbGxvY2F0ZWQgYW1vdW50XG4gICAqL1xuICBnZXRBbGxvY2F0ZWRBbW91bnQoYWxsb2NhdGlvbnM6IFRyYW5zYWN0aW9uQWxsb2NhdGlvbkNvbGxlY3Rpb24pOiBudW1iZXIge1xuICAgIHJldHVybiBhbGxvY2F0aW9ucy5nZXRCeUJhbmtUcmFuc2FjdGlvbnNJZHMoW3RoaXMuaWRdKS5hbW91bnQ7XG4gIH1cblxuICAvKipcbiAgICogR2V0IGJhbmsgdHJhbnNhY3Rpb24gdW5hbGxvY2F0ZWQgYW1vdW50XG4gICAqL1xuICBnZXRVbmFsbG9jYXRlZEFtb3VudChhbGxvY2F0aW9uczogVHJhbnNhY3Rpb25BbGxvY2F0aW9uQ29sbGVjdGlvbik6IG51bWJlciB7XG4gICAgcmV0dXJuIHRoaXMuYW1vdW50IC0gdGhpcy5nZXRBbGxvY2F0ZWRBbW91bnQoYWxsb2NhdGlvbnMpO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* type of export table column value
|
|
3
|
+
*/
|
|
4
|
+
export var ExportCellTypeEnum;
|
|
5
|
+
(function (ExportCellTypeEnum) {
|
|
6
|
+
ExportCellTypeEnum[ExportCellTypeEnum["STRING"] = 0] = "STRING";
|
|
7
|
+
ExportCellTypeEnum[ExportCellTypeEnum["CURRENCY"] = 1] = "CURRENCY";
|
|
8
|
+
ExportCellTypeEnum[ExportCellTypeEnum["DATE"] = 2] = "DATE";
|
|
9
|
+
})(ExportCellTypeEnum || (ExportCellTypeEnum = {}));
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhwb3J0LWNlbGwtdHlwZS5lbnVtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHQtY29yZS9zcmMvbGliL21vZGVscy9leHBvcnQvZXhwb3J0LWNlbGwtdHlwZS5lbnVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsTUFBTSxDQUFOLElBQVksa0JBSVg7QUFKRCxXQUFZLGtCQUFrQjtJQUM1QiwrREFBTSxDQUFBO0lBQ04sbUVBQVEsQ0FBQTtJQUNSLDJEQUFJLENBQUE7QUFDTixDQUFDLEVBSlcsa0JBQWtCLEtBQWxCLGtCQUFrQixRQUk3QiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogdHlwZSBvZiBleHBvcnQgdGFibGUgY29sdW1uIHZhbHVlXG4gKi9cbmV4cG9ydCBlbnVtIEV4cG9ydENlbGxUeXBlRW51bSB7XG4gIFNUUklORyxcbiAgQ1VSUkVOQ1ksXG4gIERBVEVcbn1cbiJdfQ==
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* export table column
|
|
3
|
+
*/
|
|
4
|
+
export class ExportCell {
|
|
5
|
+
}
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhwb3J0LWNlbGwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dC1jb3JlL3NyYy9saWIvbW9kZWxzL2V4cG9ydC9leHBvcnQtY2VsbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQTs7R0FFRztBQUNILE1BQU0sT0FBTyxVQUFVO0NBR3RCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRXhwb3J0Q2VsbFR5cGVFbnVtIH0gZnJvbSAnLi9leHBvcnQtY2VsbC10eXBlLmVudW0nO1xuXG4vKipcbiAqIGV4cG9ydCB0YWJsZSBjb2x1bW5cbiAqL1xuZXhwb3J0IGNsYXNzIEV4cG9ydENlbGwge1xuICB2YWx1ZTogYW55O1xuICB0eXBlOiBFeHBvcnRDZWxsVHlwZUVudW1cbn1cbiJdfQ==
|
|
@@ -1,9 +1,3 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Data table structure suitable for export
|
|
3
|
-
*/
|
|
4
1
|
export class ExportDataTable {
|
|
5
|
-
constructor() {
|
|
6
|
-
this.footer = [];
|
|
7
|
-
}
|
|
8
2
|
}
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhwb3J0LWRhdGEtdGFibGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dC1jb3JlL3NyYy9saWIvbW9kZWxzL2V4cG9ydC9leHBvcnQtZGF0YS10YWJsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLQSxNQUFNLE9BQU8sZUFBZTtDQUszQiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRGF0YSB0YWJsZSBzdHJ1Y3R1cmUgc3VpdGFibGUgZm9yIGV4cG9ydFxuICovXG5pbXBvcnQgeyBFeHBvcnRDZWxsIH0gZnJvbSAnLi9leHBvcnQtY2VsbCc7XG5cbmV4cG9ydCBjbGFzcyBFeHBvcnREYXRhVGFibGUge1xuICBjYXB0aW9uPzogc3RyaW5nO1xuICBoZWFkZXI6IHN0cmluZ1tdO1xuICBib2R5OiBFeHBvcnRDZWxsW11bXTtcbiAgZm9vdGVyOiBFeHBvcnRDZWxsW11bXVxufVxuIl19
|
|
@@ -42,4 +42,4 @@ export class IncomeSourceChartData {
|
|
|
42
42
|
return chartData;
|
|
43
43
|
}
|
|
44
44
|
}
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5jb21lLXNvdXJjZS1jaGFydC1kYXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHQtY29yZS9zcmMvbGliL21vZGVscy9pbmNvbWUtc291cmNlL2luY29tZS1zb3VyY2UtY2hhcnQtZGF0YS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDakUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDN0UsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBRXRFOztHQUVHO0FBQ0gsTUFBTSxPQUFPLHFCQUFxQjtJQUloQyxZQUNFLHNCQUE4QixFQUM5QixZQUFtQztRQUVuQyxJQUFJLENBQUMsc0JBQXNCLEdBQUcsc0JBQXNCLENBQUM7UUFDckQsSUFBSSxDQUFDLFlBQVksR0FBRyxZQUFZLENBQUM7SUFDbkMsQ0FBQztJQUVEOztPQUVHO0lBQ0gsR0FBRztRQUNELE1BQU0sU0FBUyxHQUFpQixDQUFDO2dCQUMvQixFQUFFLEVBQUUsY0FBYztnQkFDbEIsSUFBSSxFQUFFLGVBQWU7Z0JBQ3JCLElBQUksRUFBRSxFQUFFO2dCQUNSLHVGQUF1RjtnQkFDdkYsS0FBSyxFQUFFLENBQUM7d0JBQ04saUNBQWlDO3dCQUNqQyxLQUFLLEVBQUUsSUFBSSxhQUFhLEVBQUUsQ0FBQyxZQUFZLENBQUMsSUFBSSxJQUFJLEVBQUUsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLE9BQU8sRUFBRTt3QkFDeEUsU0FBUyxFQUFFLE9BQU87cUJBQ25CLEVBQUU7d0JBQ0QscUJBQXFCO3dCQUNyQixTQUFTLEVBQUUsTUFBTTtxQkFDbEIsQ0FBQzthQUNILEVBQUU7Z0JBQ0QsRUFBRSxFQUFFLGtCQUFrQjtnQkFDdEIsSUFBSSxFQUFFLG1CQUFtQjtnQkFDekIsSUFBSSxFQUFFLEVBQUU7YUFDVCxDQUFDLENBQUM7UUFFSCxLQUFLLE1BQU0sR0FBRyxJQUFJLGtCQUFrQixFQUFFO1lBQ3BDLElBQUksa0JBQWtCLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxFQUFFO2dCQUMxQyw0Q0FBNEM7Z0JBQzVDLE1BQU0sMEJBQTBCLEdBQTBCLElBQUksQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDLENBQUMsZUFBZSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7Z0JBRTlHLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxhQUFhLEVBQUUsQ0FBQyxZQUFZLENBQUMsQ0FBQyxlQUFlLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRSwwQkFBMEIsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO2dCQUMvSCxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLElBQUksYUFBYSxFQUFFLENBQUMsWUFBWSxDQUFDLENBQUMsZUFBZSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsSUFBSSxDQUFDLHNCQUFzQixHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUM7YUFDL0g7U0FDRjtRQUVELE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRyYW5zYWN0aW9uQ29sbGVjdGlvbiB9IGZyb20gJy4uLy4uL2NvbGxlY3Rpb25zL3RyYW5zYWN0aW9uL3RyYW5zYWN0aW9uLmNvbGxlY3Rpb24nO1xuaW1wb3J0IHsgSUNoYXJ0RGF0YSB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvY2hhcnQtZGF0YS5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgRmluYW5jaWFsWWVhciB9IGZyb20gJy4uL2ZpbmFuY2lhbC15ZWFyL2ZpbmFuY2lhbC15ZWFyJztcbmltcG9ydCB7IE1vbnRoTmFtZVNob3J0RW51bSB9IGZyb20gJy4uL2ZpbmFuY2lhbC15ZWFyL21vbnRoLW5hbWUtc2hvcnQuZW51bSc7XG5pbXBvcnQgeyBNb250aE51bWJlckVudW0gfSBmcm9tICcuLi9maW5hbmNpYWwteWVhci9tb250aC1udW1iZXIuZW51bSc7XG5cbi8qKlxuICogSW5jb21lIHNvdXJjZXMgY2hhcnQgZGF0YVxuICovXG5leHBvcnQgY2xhc3MgSW5jb21lU291cmNlQ2hhcnREYXRhIHtcbiAgcHJpdmF0ZSBmb3JlY2FzdGVkSW5jb21lQW1vdW50OiBudW1iZXI7XG4gIHByaXZhdGUgdHJhbnNhY3Rpb25zOiBUcmFuc2FjdGlvbkNvbGxlY3Rpb247XG5cbiAgY29uc3RydWN0b3IoXG4gICAgZm9yZWNhc3RlZEluY29tZUFtb3VudDogbnVtYmVyLFxuICAgIHRyYW5zYWN0aW9uczogVHJhbnNhY3Rpb25Db2xsZWN0aW9uLFxuICApIHtcbiAgICB0aGlzLmZvcmVjYXN0ZWRJbmNvbWVBbW91bnQgPSBmb3JlY2FzdGVkSW5jb21lQW1vdW50O1xuICAgIHRoaXMudHJhbnNhY3Rpb25zID0gdHJhbnNhY3Rpb25zO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCBwcmVwYXJlZCBkYXRhIGZvciBpbmNvbWUgc291cmNlcyBjaGFydFxuICAgKi9cbiAgZ2V0KCk6IElDaGFydERhdGFbXSB7XG4gICAgY29uc3QgY2hhcnREYXRhOiBJQ2hhcnREYXRhW10gPSBbe1xuICAgICAgaWQ6ICdhY3R1YWxJbmNvbWUnLFxuICAgICAgbmFtZTogJ0FjdHVhbCBJbmNvbWUnLFxuICAgICAgZGF0YTogW10sXG4gICAgICAvLyBkaXNwbGF5IGZ1dHVyZSBhY3R1YWwgaW5jb21lcyB3aXRoIGRhc2ggbGluZSBhbmQgcGFzdCBhY3R1YWwgaW5jb21lcyB3aXRoIHNvbGlkIGxpbmVcbiAgICAgIHpvbmVzOiBbe1xuICAgICAgICAvLyBsaW5lIHN0eWxlIGFmdGVyIGN1cnJlbnQgbW9udGhcbiAgICAgICAgdmFsdWU6IG5ldyBGaW5hbmNpYWxZZWFyKCkuZ2V0TW9udGhEYXRlKG5ldyBEYXRlKCkuZ2V0TW9udGgoKSkuZ2V0VGltZSgpLFxuICAgICAgICBkYXNoU3R5bGU6ICdTb2xpZCdcbiAgICAgIH0sIHtcbiAgICAgICAgLy8gZGVmYXVsdCBsaW5lIHN0eWxlXG4gICAgICAgIGRhc2hTdHlsZTogJ0Rhc2gnXG4gICAgICB9XVxuICAgIH0sIHtcbiAgICAgIGlkOiAnZm9yZWNhc3RlZEluY29tZScsXG4gICAgICBuYW1lOiAnRm9yZWNhc3RlZCBJbmNvbWUnLFxuICAgICAgZGF0YTogW10sXG4gICAgfV07XG5cbiAgICBmb3IgKGNvbnN0IGtleSBpbiBNb250aE5hbWVTaG9ydEVudW0pIHtcbiAgICAgIGlmIChNb250aE5hbWVTaG9ydEVudW0uaGFzT3duUHJvcGVydHkoa2V5KSkge1xuICAgICAgICAvLyB0cmFuc2FjdGlvbiBjb2xsZWN0aW9uIGZvciBwcm92aWRlZCBtb250aFxuICAgICAgICBjb25zdCBtb250aFRyYW5zYWN0aW9uQ29sbGVjdGlvbjogVHJhbnNhY3Rpb25Db2xsZWN0aW9uID0gdGhpcy50cmFuc2FjdGlvbnMuZ2V0QnlNb250aCgrTW9udGhOdW1iZXJFbnVtW2tleV0pO1xuXG4gICAgICAgIGNoYXJ0RGF0YVswXS5kYXRhLnB1c2goW25ldyBGaW5hbmNpYWxZZWFyKCkuZ2V0TW9udGhEYXRlKCtNb250aE51bWJlckVudW1ba2V5XSkuZ2V0VGltZSgpLCBtb250aFRyYW5zYWN0aW9uQ29sbGVjdGlvbi5hbW91bnRdKTtcbiAgICAgICAgY2hhcnREYXRhWzFdLmRhdGEucHVzaChbbmV3IEZpbmFuY2lhbFllYXIoKS5nZXRNb250aERhdGUoK01vbnRoTnVtYmVyRW51bVtrZXldKS5nZXRUaW1lKCksIHRoaXMuZm9yZWNhc3RlZEluY29tZUFtb3VudCAvIDEyXSk7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIGNoYXJ0RGF0YTtcbiAgfVxufVxuIl19
|
|
@@ -1,34 +1,12 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import {
|
|
3
|
-
import { ExportRow } from '../export/export-row';
|
|
4
|
-
import { ExportRowDataTypeEnum } from '../export/export-row-data-type.enum';
|
|
5
|
-
export const EXPORT_DATA_TABLE_COLUMNS = [
|
|
6
|
-
'Pmt No.',
|
|
7
|
-
'Date',
|
|
8
|
-
'Payment Due',
|
|
9
|
-
'Interest Accrued',
|
|
10
|
-
'Principal Paid',
|
|
11
|
-
'Principal Balance',
|
|
12
|
-
'Payout'
|
|
13
|
-
];
|
|
2
|
+
import { Type } from 'class-transformer';
|
|
14
3
|
// @Todo no base model from backend list
|
|
15
4
|
/**
|
|
16
5
|
* Loan payment class
|
|
17
6
|
*/
|
|
18
7
|
export class LoanPayment {
|
|
19
|
-
toDataTableRows() {
|
|
20
|
-
return [
|
|
21
|
-
plainToClass(ExportRow, { data: this.number, type: ExportRowDataTypeEnum.STRING }),
|
|
22
|
-
plainToClass(ExportRow, { data: this.date, type: ExportRowDataTypeEnum.DATE }),
|
|
23
|
-
plainToClass(ExportRow, { data: this.paymentDue, type: ExportRowDataTypeEnum.CURRENCY }),
|
|
24
|
-
plainToClass(ExportRow, { data: this.interestAccrued, type: ExportRowDataTypeEnum.CURRENCY }),
|
|
25
|
-
plainToClass(ExportRow, { data: this.principalPaid, type: ExportRowDataTypeEnum.CURRENCY }),
|
|
26
|
-
plainToClass(ExportRow, { data: this.principalBalance, type: ExportRowDataTypeEnum.CURRENCY }),
|
|
27
|
-
plainToClass(ExportRow, { data: this.payout, type: ExportRowDataTypeEnum.CURRENCY }),
|
|
28
|
-
];
|
|
29
|
-
}
|
|
30
8
|
}
|
|
31
9
|
__decorate([
|
|
32
10
|
Type(() => Date)
|
|
33
11
|
], LoanPayment.prototype, "date", void 0);
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hbi1wYXltZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHQtY29yZS9zcmMvbGliL21vZGVscy9sb2FuL2xvYW4tcGF5bWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRXpDLHdDQUF3QztBQUN4Qzs7R0FFRztBQUNILE1BQU0sT0FBTyxXQUFXO0NBV3ZCO0FBVEM7SUFEQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDO3lDQUNOIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHlwZSB9IGZyb20gJ2NsYXNzLXRyYW5zZm9ybWVyJztcblxuLy8gQFRvZG8gbm8gYmFzZSBtb2RlbCBmcm9tIGJhY2tlbmQgbGlzdFxuLyoqXG4gKiBMb2FuIHBheW1lbnQgY2xhc3NcbiAqL1xuZXhwb3J0IGNsYXNzIExvYW5QYXltZW50IHtcbiAgQFR5cGUoKCkgPT4gRGF0ZSlcbiAgZGF0ZTogRGF0ZTtcbiAgaW50ZXJlc3RBY2NydWVkOiBudW1iZXI7XG4gIGludGVyZXN0QmFsYW5jZTogbnVtYmVyO1xuICBudW1iZXI6IG51bWJlcjtcbiAgcGF5bWVudER1ZTogbnVtYmVyO1xuICBwcmluY2lwYWxCYWxhbmNlOiBudW1iZXI7XG4gIHByaW5jaXBhbFBhaWQ6IG51bWJlcjtcbiAgcGF5b3V0OiBudW1iZXI7XG4gIHRvdGFsT3dlZDogbnVtYmVyO1xufVxuIl19
|
|
@@ -88,4 +88,4 @@ export class VehicleClaim extends VehicleClaimBase {
|
|
|
88
88
|
return ChartAccountsListEnum.KLMS_TRAVELLED;
|
|
89
89
|
}
|
|
90
90
|
}
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vehicle-claim.js","sourceRoot":"","sources":["../../../../../../projects/tt-core/src/lib/models/logbook/vehicle-claim.ts"],"names":[],"mappings":"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","sourcesContent":["import { VehicleClaim as VehicleClaimBase } from '../../db/Models/vehicle/vehicle-claim';\nimport { VehicleClaimMethodEnum } from '../../db/Enums/vehicle-claim-method.enum';\nimport { FinancialYear } from '../financial-year/financial-year';\nimport { TankTypeEnum } from '../../db/Enums/tank-type.enum';\nimport { plainToClass } from 'class-transformer';\nimport { TransactionSourceEnum } from '../../db/Enums/transaction-source.enum';\nimport { TransactionTypeEnum } from '../../db/Enums/transaction-type.enum';\nimport { ChartAccountsListEnum } from '../../db/Enums/chart-accounts-list.enum';\nimport { Transaction } from '../transaction/transaction';\nimport { TransactionCollection } from '../../collections/transaction/transaction.collection';\n\nconst WEEKS_IN_YEAR = 52;\n\nexport class VehicleClaim extends VehicleClaimBase {\n  // limit for kms claim method\n  kmsLimit: number = 5000;\n  financialYear: number = new FinancialYear().year;\n\n  method: VehicleClaimMethodEnum = VehicleClaimMethodEnum.KMS;\n  kilometers: number = 0;\n  workUsage: number = 0;\n  isManual: boolean = true;\n\n  /**\n   * get amount of kilometres per week\n   */\n  get averageWeeklyTraveledKms(): number {\n    return this.kilometers / WEEKS_IN_YEAR;\n  }\n\n  isLogbookMethod(): boolean {\n    return this.method === VehicleClaimMethodEnum.LOGBOOK;\n  }\n\n  isKLMsMethod(): boolean {\n    return this.method === VehicleClaimMethodEnum.KMS;\n  }\n\n  isWorkTank(): boolean {\n    return this.tankType === TankTypeEnum.WORK;\n  }\n\n  isSoleTank(): boolean {\n    return this.tankType === TankTypeEnum.SOLE;\n  }\n\n  /**\n   * Claim amount for KLMs method. Exists only for KLMs method.\n   */\n  getKLMsClaimAmount(vehicleClaimRate: number): number {\n    if (!this.isKLMsMethod()) {\n      return 0;\n    }\n\n    return +(this.kilometers * vehicleClaimRate).toFixed(2);\n  }\n\n  /**\n   * Get logbook claim amount. Exists only for logbook method.\n   * ClaimAmount = WorkUsage * transaction/depreciation amount\n   */\n  getLogbookClaimAmount(transactions: TransactionCollection): number {\n    if (!this.isLogbookMethod()) {\n      return 0;\n    }\n\n    const transactionsAmount: number = transactions\n      .getByTankType(this.tankType)\n      .getVehicleTransactions()\n      // except klms transactions because they needed only for klms method\n      .filter((transaction: Transaction): boolean => !transaction.chartAccounts.isKLMsByTankType(this.tankType))\n      .sumBy('amount');\n\n    // Math.abs because amount will be negative (because we sum expenses), but we don't want negative percent value\n    return Math.abs(transactionsAmount) * this.workUsage / 100;\n  }\n\n  /**\n   * Create KLMs transaction based on vehicle claim and vehicle claim rate\n   * @TODO handle on backend: Create klms transaction when vhicle claim created\n   */\n  toTransaction(vehicleClaimRate: number): Transaction {\n    return plainToClass(Transaction, {\n      amount: this.kilometers * vehicleClaimRate,\n      source: TransactionSourceEnum.CASH,\n      type: TransactionTypeEnum.DEBIT,\n      taxWithheld: 0,\n      description: 'Klm’s method',\n      date: new Date(`${new FinancialYear().year}-06-30`),\n      claimPercent: 100,\n      chartAccounts: {\n        id: this.getKlmsChartAccountsIdByTankType(this.tankType)\n      }\n    });\n  }\n\n  getKlmsChartAccountsIdByTankType(tankType: TankTypeEnum = this.tankType): number {\n    if (tankType === TankTypeEnum.WORK) {\n      return ChartAccountsListEnum.KLMS_TRAVELLED_FOR_WORK;\n    }\n\n    return ChartAccountsListEnum.KLMS_TRAVELLED\n  }\n}\n"]}
|
|
@@ -152,4 +152,4 @@ export class PropertyEquityChartData {
|
|
|
152
152
|
});
|
|
153
153
|
}
|
|
154
154
|
}
|
|
155
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-equity-chart-data.js","sourceRoot":"","sources":["../../../../../../projects/tt-core/src/lib/models/property/property-equity-chart-data.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,cAAc,CAAC;AACjC,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AAIvE,OAAO,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAC;AACjE,OAAO,EAAE,2BAA2B,EAAE,MAAM,mCAAmC,CAAC;AAIhF,mCAAmC;AACnC,MAAM,cAAc,GAAW,EAAE,CAAC;AAElC;;;;;GAKG;AACH,MAAM,OAAO,uBAAuB;IAUlC,YACE,UAA8B,EAC9B,YAAmC,EACnC,KAAqB,EACb,YAAkB;QAAlB,iBAAY,GAAZ,YAAY,CAAM;QAE1B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC,eAAe,EAAE,CAAC;QACnD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,WAAW,GAAG,IAAI,aAAa,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC;QACtD,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAED;;;OAGG;IACH,cAAc,CAAC,IAAiC;QAC9C,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAA6B,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;IAC/E,CAAC;IAED;;OAEG;IACH,YAAY;QACV,OAAO;YACL;gBACE,EAAE,EAAE,aAAa;gBACjB,IAAI,EAAE,cAAc;gBACpB,MAAM,EAAE,IAAI,CAAC,cAAc,CAAC,2BAA2B,CAAC,YAAY,CAAC;gBACrE,mFAAmF;gBACnF,KAAK,EAAE,CAAC;wBACN,yCAAyC;wBACzC,KAAK,EAAE,IAAI,CAAC,WAAW;wBACvB,SAAS,EAAE,OAAO;qBACnB,EAAE;wBACD,qBAAqB;wBACrB,SAAS,EAAE,MAAM;qBAClB,CAAC;aACH;YACD;gBACE,uCAAuC;gBACvC,EAAE,EAAE,aAAa;gBACjB,IAAI,EAAE,cAAc;gBACpB,MAAM,EAAE,IAAI,CAAC,cAAc,CAAC,2BAA2B,CAAC,YAAY,CAAC;aACtE;SACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACK,SAAS;QACf,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACf,KAAK,IAAI,IAAI,GAAW,IAAI,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,GAAG,CAAC,EAAE,IAAI,IAAI,CAAC,IAAI,CAAC,WAAW,GAAG,cAAc,CAAC,EAAE,IAAI,EAAE,EAAE;YAC1H,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,uBAAuB,CAAC,IAAI,CAAC,CAAC,CAAC;SACnD;IACH,CAAC;IAED;;OAEG;IACK,iBAAiB;QACvB,uCAAuC;QACvC,MAAM,KAAK,GAA8B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAA6B,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC;QAC5H,KAAK,CAAC,OAAO,CAAC,CAAC,IAA6B,EAAE,EAAE;YAC9C,oEAAoE;YACpE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,GAAW,EAAE,QAAkB,EAAU,EAAE;gBAC1F,OAAO,GAAG,GAAG,IAAI,CAAC,+BAA+B,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YACzE,CAAC,EAAE,CAAC,CAAC,CAAC;YAEN,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,GAAW,EAAE,QAAkB,EAAU,EAAE;gBACnG,OAAO,GAAG,GAAG,IAAI,CAAC,+BAA+B,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YACzE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACT,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;OAGG;IACK,eAAe;QACrB,MAAM,IAAI,GAA4B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAA0B,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,WAAW,CAAC,CAAC;QAClH,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC;QAC/C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,GAAW,EAAE,QAAkB,EAAU,EAAE;YAC1F,OAAO,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,wBAAwB,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC;QACjF,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;IAED;;OAEG;IACK,oBAAoB;QAC1B,wDAAwD;QACxD,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,QAAkB,EAAE,EAAE;YACnD,IAAI,qBAAqB,GAAW,CAAC,QAAQ,CAAC,aAAa,GAAG,GAAG,CAAC,GAAG,QAAQ,CAAC,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC;YAEjH,6EAA6E;YAC7E,IAAI,CAAC,IAAI;iBACN,MAAM,CAAC,CAAC,IAA6B,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC;iBACvE,OAAO,CAAC,CAAC,IAA6B,EAAE,EAAE;gBACzC,MAAM,oBAAoB,GAA0B,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;gBACnG,iEAAiE;gBACjE,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,EAAE,oBAAoB,EAAE,IAAI,CAAC,KAAK,CAAC,oBAAoB,CAAC,oBAAoB,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;gBAEzJ,iEAAiE;gBACjE,IAAI,CAAC,WAAW,IAAI,qBAAqB,CAAC;gBAE1C,sEAAsE;gBACtE,qBAAqB,IAAI,qBAAqB,GAAG,CAAC,QAAQ,CAAC,aAAa,GAAG,GAAG,CAAC,CAAC;YAClF,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;OAOG;IACK,oBAAoB,CAAC,QAAkB,EAAE,IAAY,EAAE,YAAmC,EAAE,KAAqB;QACvH,OAAO,YAAY,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,QAAgB,EAAE,WAAwB,EAAU,EAAE;;YACtF,OAAO,QAAQ,GAAG,CAAC,WAAW,CAAC,qBAAqB,CAAC,QAAQ,CAAC,EAAE,CAAC,GAAG,CAAC,CAAA,MAAA,MAAA,KAAK,CAAC,kBAAkB,CAAC,WAAW,CAAC,EAAE,CAAC,0CAAE,oBAAoB,CAAC,IAAI,CAAC,0CAAE,SAAS,KAAI,CAAC,CAAC,CAAC,CAAC;QAC9J,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;IAED,+BAA+B,CAAC,QAAkB,EAAE,IAAY;QAC9D,IAAI,IAAI,aAAa,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,IAAI,GAAG,IAAI,EAAE;YACxD,OAAO,CAAC,CAAC;SACV;QAED,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC;IACrF,CAAC;IAED,+BAA+B,CAAC,QAAkB,EAAE,IAAY;;QAC9D,IAAI,IAAI,aAAa,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,IAAI,GAAG,IAAI,EAAE;YACxD,OAAO,CAAC,CAAC;SACV;QAED,OAAO,CAAA,MAAA,QAAQ,CAAC,iBAAiB,CAAC,IAAI,CAAC,0CAAE,WAAW,KAAI,IAAI,CAAC,YAAY,CAAC,wBAAwB,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IAClH,CAAC;IAED;;OAEG;IACK,oBAAoB;QAC1B,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAA6B,EAAE,EAAE;YAClD,IAAI,IAAI,CAAC,WAAW,KAAK,CAAC,EAAE;gBAC1B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;aACzB;QACH,CAAC,CAAC,CAAC;IACL,CAAC;CACF","sourcesContent":["import first from 'lodash/first';\nimport { PropertyEquityChartItem } from './property-equity-chart-item';\nimport { PropertyCollection } from '../../collections/property/property.collection';\nimport { BankAccountCollection } from '../../collections/bank-account.collection';\nimport { LoanCollection } from '../../collections/loan.collection';\nimport { FinancialYear } from '../financial-year/financial-year';\nimport { PropertyEquityChartTypeEnum } from './property-equity-chart-type.enum';\nimport { Property } from './property';\nimport { BankAccount } from '../bank/bank-account';\n\n// count of years for future values\nconst FORECAST_YEARS: number = 25;\n\n/**\n * class contain actual and forecasted market values and loan balances for passed properties\n * X axis - years from the first actual data year to the last forecasted year\n * Y axis - amounts of market values, loan balances\n * Also on hover appear equity positions point\n */\nexport class PropertyEquityChartData {\n  // list of equity positions for all years range\n  list: PropertyEquityChartItem[];\n  // current financial year\n  currentYear: number;\n  // list of properties this collection based on\n  private properties: PropertyCollection;\n  private bankAccounts: BankAccountCollection;\n  private loans: LoanCollection;\n\n  constructor(\n    properties: PropertyCollection,\n    bankAccounts: BankAccountCollection,\n    loans: LoanCollection,\n    private registerDate: Date\n  ) {\n    this.properties = properties;\n    this.bankAccounts = bankAccounts.getLoanAccounts();\n    this.loans = loans;\n    this.currentYear = new FinancialYear(new Date()).year;\n    this.initItems();\n    this.buildHistoryItems();\n    this.buildActualItem();\n    this.buildForecastedItems();\n    this.checkZeroLoanBalance();\n  }\n\n  /**\n   * get items list in chart series format\n   * @param type\n   */\n  getChartSeries(type: PropertyEquityChartTypeEnum): number[][] {\n    return this.list.map((item: PropertyEquityChartItem) => item.getSerie(type));\n  }\n\n  /**\n   * get prepared chart data\n   */\n  getChartData(): object[] {\n    return [\n      {\n        id: 'marketValue',\n        name: 'Market Value',\n        series: this.getChartSeries(PropertyEquityChartTypeEnum.MARKET_VALUE),\n        // display future market value with dash line and past market value with solid line\n        zones: [{\n          // line style after current calendar year\n          value: this.currentYear,\n          dashStyle: 'Solid'\n        }, {\n          // default line style\n          dashStyle: 'Dash'\n        }]\n      },\n      {\n        // id used to add/remove serie to chart\n        id: 'loanBalance',\n        name: 'Loan Balance',\n        series: this.getChartSeries(PropertyEquityChartTypeEnum.LOAN_BALANCE)\n      }\n    ];\n  }\n\n  /**\n   * create empty equity position item for each year in collection\n   */\n  private initItems(): void {\n    this.list = [];\n    for (let year: number = new FinancialYear(this.registerDate).year - 1; year <= (this.currentYear + FORECAST_YEARS); year++) {\n      this.list.push(new PropertyEquityChartItem(year));\n    }\n  }\n\n  /**\n   * collect equity position items with past values from properties forecasts\n   */\n  private buildHistoryItems(): void {\n    // get items for past and current years\n    const items: PropertyEquityChartItem[] = this.list.filter((item: PropertyEquityChartItem) => item.year <= this.currentYear);\n    items.forEach((item: PropertyEquityChartItem) => {\n      // increase item values with property actual forecasts for item year\n      item.marketValue = this.properties.items.reduce((sum: number, property: Property): number => {\n        return sum + this.getMarketValueForPropertyByYear(property, item.year);\n      }, 0);\n\n      item.loanBalance = Math.abs(this.properties.items.reduce((sum: number, property: Property): number => {\n        return sum + this.getLoanBalanceForPropertyByYear(property, item.year);\n      }, 0));\n    });\n  }\n\n  /**\n   * set actual year's real data\n   * @private\n   */\n  private buildActualItem(): void {\n    const item: PropertyEquityChartItem = this.list.find((i: PropertyEquityChartItem) => i.year === this.currentYear);\n    item.marketValue = this.properties.marketValue;\n    item.loanBalance = this.properties.items.reduce((sum: number, property: Property): number => {\n      return sum + Math.abs(this.bankAccounts.getPropertyBalanceAmount(property.id));\n    }, 0);\n  }\n\n  /**\n   * collect equity position items with forecasted (future) calculated values\n   */\n  private buildForecastedItems(): void {\n    // calculate future values for all properties separately\n    this.properties.items.forEach((property: Property) => {\n      let forecastedMarketValue: number = (property.growthPercent / 100) * property.marketValue + property.marketValue;\n\n      // calculate future values for each future year for current handling property\n      this.list\n        .filter((item: PropertyEquityChartItem) => item.year > this.currentYear)\n        .forEach((item: PropertyEquityChartItem) => {\n          const propertyBankAccounts: BankAccountCollection = this.bankAccounts.getByPropertyId(property.id);\n          // increase loan balance amount for handling equity position item\n          item.loanBalance += this.getLoanBalanceByYear(property, item.year, propertyBankAccounts, this.loans.getByBankAccountsIds(propertyBankAccounts.getIds()));\n\n          // increase market value amount for handling equity position item\n          item.marketValue += forecastedMarketValue;\n\n          // increase current market value forecast for the next cycle iteration\n          forecastedMarketValue += forecastedMarketValue * (property.growthPercent / 100);\n        });\n    });\n  }\n\n  /**\n   * Get property loan balance by financial year\n   * @param property Property instance for filter\n   * @param year Financial year number\n   * @param bankAccounts List of bank accounts\n   * @param loans List of loans\n   * @private\n   */\n  private getLoanBalanceByYear(property: Property, year: number, bankAccounts: BankAccountCollection, loans: LoanCollection): number {\n    return bankAccounts.items.reduce((totalSum: number, bankAccount: BankAccount): number => {\n      return totalSum + (bankAccount.getPropertyPercentage(property.id) * (loans.getByBankAccountId(bankAccount.id)?.getLastPaymentByYear(year)?.totalOwed || 0));\n    }, 0);\n  }\n\n  getMarketValueForPropertyByYear(property: Property, year: number): number {\n    if (new FinancialYear(property.contractDate).year > year) {\n      return 0;\n    }\n\n    return (property.getForecastByYear(year) || first(property.forecasts)).marketValue;\n  }\n\n  getLoanBalanceForPropertyByYear(property: Property, year: number): number {\n    if (new FinancialYear(property.contractDate).year > year) {\n      return 0;\n    }\n\n    return property.getForecastByYear(year)?.loanBalance || this.bankAccounts.getPropertyBalanceAmount(property.id);\n  }\n\n  /**\n   * Check if loan balance is 0 and set it as null (to not to draw point on the chart)\n   */\n  private checkZeroLoanBalance(): void {\n    this.list.forEach((item: PropertyEquityChartItem) => {\n      if (item.loanBalance === 0) {\n        item.loanBalance = null;\n      }\n    });\n  }\n}\n"]}
|
|
155
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-equity-chart-data.js","sourceRoot":"","sources":["../../../../../../projects/tt-core/src/lib/models/property/property-equity-chart-data.ts"],"names":[],"mappings":"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","sourcesContent":["import first from 'lodash/first';\nimport { PropertyEquityChartItem } from './property-equity-chart-item';\nimport { PropertyCollection } from '../../collections/property/property.collection';\nimport { BankAccountCollection } from '../../collections/bank-account.collection';\nimport { LoanCollection } from '../../collections/loan/loan.collection';\nimport { FinancialYear } from '../financial-year/financial-year';\nimport { PropertyEquityChartTypeEnum } from './property-equity-chart-type.enum';\nimport { Property } from './property';\nimport { BankAccount } from '../bank/bank-account';\n\n// count of years for future values\nconst FORECAST_YEARS: number = 25;\n\n/**\n * class contain actual and forecasted market values and loan balances for passed properties\n * X axis - years from the first actual data year to the last forecasted year\n * Y axis - amounts of market values, loan balances\n * Also on hover appear equity positions point\n */\nexport class PropertyEquityChartData {\n  // list of equity positions for all years range\n  list: PropertyEquityChartItem[];\n  // current financial year\n  currentYear: number;\n  // list of properties this collection based on\n  private properties: PropertyCollection;\n  private bankAccounts: BankAccountCollection;\n  private loans: LoanCollection;\n\n  constructor(\n    properties: PropertyCollection,\n    bankAccounts: BankAccountCollection,\n    loans: LoanCollection,\n    private registerDate: Date\n  ) {\n    this.properties = properties;\n    this.bankAccounts = bankAccounts.getLoanAccounts();\n    this.loans = loans;\n    this.currentYear = new FinancialYear(new Date()).year;\n    this.initItems();\n    this.buildHistoryItems();\n    this.buildActualItem();\n    this.buildForecastedItems();\n    this.checkZeroLoanBalance();\n  }\n\n  /**\n   * get items list in chart series format\n   * @param type\n   */\n  getChartSeries(type: PropertyEquityChartTypeEnum): number[][] {\n    return this.list.map((item: PropertyEquityChartItem) => item.getSerie(type));\n  }\n\n  /**\n   * get prepared chart data\n   */\n  getChartData(): object[] {\n    return [\n      {\n        id: 'marketValue',\n        name: 'Market Value',\n        series: this.getChartSeries(PropertyEquityChartTypeEnum.MARKET_VALUE),\n        // display future market value with dash line and past market value with solid line\n        zones: [{\n          // line style after current calendar year\n          value: this.currentYear,\n          dashStyle: 'Solid'\n        }, {\n          // default line style\n          dashStyle: 'Dash'\n        }]\n      },\n      {\n        // id used to add/remove serie to chart\n        id: 'loanBalance',\n        name: 'Loan Balance',\n        series: this.getChartSeries(PropertyEquityChartTypeEnum.LOAN_BALANCE)\n      }\n    ];\n  }\n\n  /**\n   * create empty equity position item for each year in collection\n   */\n  private initItems(): void {\n    this.list = [];\n    for (let year: number = new FinancialYear(this.registerDate).year - 1; year <= (this.currentYear + FORECAST_YEARS); year++) {\n      this.list.push(new PropertyEquityChartItem(year));\n    }\n  }\n\n  /**\n   * collect equity position items with past values from properties forecasts\n   */\n  private buildHistoryItems(): void {\n    // get items for past and current years\n    const items: PropertyEquityChartItem[] = this.list.filter((item: PropertyEquityChartItem) => item.year <= this.currentYear);\n    items.forEach((item: PropertyEquityChartItem) => {\n      // increase item values with property actual forecasts for item year\n      item.marketValue = this.properties.items.reduce((sum: number, property: Property): number => {\n        return sum + this.getMarketValueForPropertyByYear(property, item.year);\n      }, 0);\n\n      item.loanBalance = Math.abs(this.properties.items.reduce((sum: number, property: Property): number => {\n        return sum + this.getLoanBalanceForPropertyByYear(property, item.year);\n      }, 0));\n    });\n  }\n\n  /**\n   * set actual year's real data\n   * @private\n   */\n  private buildActualItem(): void {\n    const item: PropertyEquityChartItem = this.list.find((i: PropertyEquityChartItem) => i.year === this.currentYear);\n    item.marketValue = this.properties.marketValue;\n    item.loanBalance = this.properties.items.reduce((sum: number, property: Property): number => {\n      return sum + Math.abs(this.bankAccounts.getPropertyBalanceAmount(property.id));\n    }, 0);\n  }\n\n  /**\n   * collect equity position items with forecasted (future) calculated values\n   */\n  private buildForecastedItems(): void {\n    // calculate future values for all properties separately\n    this.properties.items.forEach((property: Property) => {\n      let forecastedMarketValue: number = (property.growthPercent / 100) * property.marketValue + property.marketValue;\n\n      // calculate future values for each future year for current handling property\n      this.list\n        .filter((item: PropertyEquityChartItem) => item.year > this.currentYear)\n        .forEach((item: PropertyEquityChartItem) => {\n          const propertyBankAccounts: BankAccountCollection = this.bankAccounts.getByPropertyId(property.id);\n          // increase loan balance amount for handling equity position item\n          item.loanBalance += this.getLoanBalanceByYear(property, item.year, propertyBankAccounts, this.loans.getByBankAccountsIds(propertyBankAccounts.getIds()));\n\n          // increase market value amount for handling equity position item\n          item.marketValue += forecastedMarketValue;\n\n          // increase current market value forecast for the next cycle iteration\n          forecastedMarketValue += forecastedMarketValue * (property.growthPercent / 100);\n        });\n    });\n  }\n\n  /**\n   * Get property loan balance by financial year\n   * @param property Property instance for filter\n   * @param year Financial year number\n   * @param bankAccounts List of bank accounts\n   * @param loans List of loans\n   * @private\n   */\n  private getLoanBalanceByYear(property: Property, year: number, bankAccounts: BankAccountCollection, loans: LoanCollection): number {\n    return bankAccounts.items.reduce((totalSum: number, bankAccount: BankAccount): number => {\n      return totalSum + (bankAccount.getPropertyPercentage(property.id) * (loans.getByBankAccountId(bankAccount.id)?.getLastPaymentByYear(year)?.totalOwed || 0));\n    }, 0);\n  }\n\n  getMarketValueForPropertyByYear(property: Property, year: number): number {\n    if (new FinancialYear(property.contractDate).year > year) {\n      return 0;\n    }\n\n    return (property.getForecastByYear(year) || first(property.forecasts)).marketValue;\n  }\n\n  getLoanBalanceForPropertyByYear(property: Property, year: number): number {\n    if (new FinancialYear(property.contractDate).year > year) {\n      return 0;\n    }\n\n    return property.getForecastByYear(year)?.loanBalance || this.bankAccounts.getPropertyBalanceAmount(property.id);\n  }\n\n  /**\n   * Check if loan balance is 0 and set it as null (to not to draw point on the chart)\n   */\n  private checkZeroLoanBalance(): void {\n    this.list.forEach((item: PropertyEquityChartItem) => {\n      if (item.loanBalance === 0) {\n        item.loanBalance = null;\n      }\n    });\n  }\n}\n"]}
|
|
@@ -7,6 +7,15 @@ export class PropertySale extends BasePropertySale {
|
|
|
7
7
|
return this.commission + this.legalFees + this.otherCost;
|
|
8
8
|
}
|
|
9
9
|
}
|
|
10
|
+
__decorate([
|
|
11
|
+
Type(() => Number)
|
|
12
|
+
], PropertySale.prototype, "commission", void 0);
|
|
13
|
+
__decorate([
|
|
14
|
+
Type(() => Number)
|
|
15
|
+
], PropertySale.prototype, "legalFees", void 0);
|
|
16
|
+
__decorate([
|
|
17
|
+
Type(() => Number)
|
|
18
|
+
], PropertySale.prototype, "otherCost", void 0);
|
|
10
19
|
__decorate([
|
|
11
20
|
Type(() => Date)
|
|
12
21
|
], PropertySale.prototype, "settlementDate", void 0);
|
|
@@ -16,4 +25,4 @@ __decorate([
|
|
|
16
25
|
__decorate([
|
|
17
26
|
Type(() => PropertySaleTaxExemptionMetadata)
|
|
18
27
|
], PropertySale.prototype, "taxExemptionMetadata", void 0);
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvcGVydHktc2FsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3R0LWNvcmUvc3JjL2xpYi9tb2RlbHMvcHJvcGVydHkvcHJvcGVydHktc2FsZS9wcm9wZXJ0eS1zYWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsWUFBWSxJQUFJLGdCQUFnQixFQUFFLE1BQU0seURBQXlELENBQUM7QUFDM0csT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3pDLE9BQU8sRUFDTCxnQ0FBZ0MsRUFDakMsTUFBTSxnRkFBZ0YsQ0FBQztBQUV4RixNQUFNLE9BQU8sWUFBYSxTQUFRLGdCQUFnQjtJQW1CaEQsSUFBSSxvQkFBb0I7UUFDdEIsT0FBTyxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUMzRCxDQUFDO0NBQ0Y7QUFwQkM7SUFEQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUMsTUFBTSxDQUFDO2dEQUNBO0FBR25CO0lBREMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLE1BQU0sQ0FBQzsrQ0FDRDtBQUdsQjtJQURDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxNQUFNLENBQUM7K0NBQ0Q7QUFHbEI7SUFEQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDO29EQUNJO0FBR3JCO0lBREMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQztrREFDRTtBQUduQjtJQURDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxnQ0FBZ0MsQ0FBQzswREFDWSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFByb3BlcnR5U2FsZSBhcyBCYXNlUHJvcGVydHlTYWxlIH0gZnJvbSAnLi4vLi4vLi4vZGIvTW9kZWxzL3Byb3BlcnR5L3Byb3BlcnR5LXNhbGUvcHJvcGVydHktc2FsZSc7XG5pbXBvcnQgeyBUeXBlIH0gZnJvbSAnY2xhc3MtdHJhbnNmb3JtZXInO1xuaW1wb3J0IHtcbiAgUHJvcGVydHlTYWxlVGF4RXhlbXB0aW9uTWV0YWRhdGFcbn0gZnJvbSAnLi4vLi4vLi4vZGIvTW9kZWxzL3Byb3BlcnR5L3Byb3BlcnR5LXNhbGUvcHJvcGVydHktc2FsZS10YXgtZXhlbXB0aW9uLW1ldGFkYXRhJztcblxuZXhwb3J0IGNsYXNzIFByb3BlcnR5U2FsZSBleHRlbmRzIEJhc2VQcm9wZXJ0eVNhbGUge1xuICBAVHlwZSgoKSA9PiBOdW1iZXIpXG4gIGNvbW1pc3Npb246IG51bWJlcjtcblxuICBAVHlwZSgoKSA9PiBOdW1iZXIpXG4gIGxlZ2FsRmVlczogbnVtYmVyO1xuXG4gIEBUeXBlKCgpID0+IE51bWJlcilcbiAgb3RoZXJDb3N0OiBudW1iZXI7XG5cbiAgQFR5cGUoKCkgPT4gRGF0ZSlcbiAgc2V0dGxlbWVudERhdGU6IERhdGU7XG5cbiAgQFR5cGUoKCkgPT4gRGF0ZSlcbiAgY29udHJhY3REYXRlOiBEYXRlO1xuXG4gIEBUeXBlKCgpID0+IFByb3BlcnR5U2FsZVRheEV4ZW1wdGlvbk1ldGFkYXRhKVxuICB0YXhFeGVtcHRpb25NZXRhZGF0YTogUHJvcGVydHlTYWxlVGF4RXhlbXB0aW9uTWV0YWRhdGFbXTtcblxuICBnZXQgc2FsZUNvc3RzVG90YWxBbW91bnQoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gdGhpcy5jb21taXNzaW9uICsgdGhpcy5sZWdhbEZlZXMgKyB0aGlzLm90aGVyQ29zdDtcbiAgfVxufVxuIl19
|
|
@@ -9,4 +9,4 @@ export class PropertyReportItemTransaction extends PropertyReportItem {
|
|
|
9
9
|
this.description = chartAccounts.name;
|
|
10
10
|
}
|
|
11
11
|
}
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvcGVydHktcmVwb3J0LWl0ZW0tdHJhbnNhY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dC1jb3JlL3NyYy9saWIvbW9kZWxzL3JlcG9ydC9wcm9wZXJ0eS9wcm9wZXJ0eS1yZXBvcnQtaXRlbS10cmFuc2FjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUs1RDs7R0FFRztBQUNILE1BQU0sT0FBTyw2QkFBOEIsU0FBUSxrQkFBa0I7SUFDbkUsWUFDRSxZQUFtQyxFQUNuQyxRQUFrQixFQUNsQixhQUE0QjtRQUU1QixLQUFLLENBQUMsUUFBUSxFQUFFLGFBQWEsQ0FBQyxDQUFDO1FBQy9CLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDNUMsSUFBSSxDQUFDLFdBQVcsR0FBRyxhQUFhLENBQUMsSUFBSSxDQUFBO0lBQ3ZDLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFByb3BlcnR5UmVwb3J0SXRlbSB9IGZyb20gJy4vcHJvcGVydHktcmVwb3J0LWl0ZW0nO1xuaW1wb3J0IHsgVHJhbnNhY3Rpb25Db2xsZWN0aW9uIH0gZnJvbSAnLi4vLi4vLi4vY29sbGVjdGlvbnMvdHJhbnNhY3Rpb24vdHJhbnNhY3Rpb24uY29sbGVjdGlvbic7XG5pbXBvcnQgeyBQcm9wZXJ0eSB9IGZyb20gJy4uLy4uL3Byb3BlcnR5L3Byb3BlcnR5JztcbmltcG9ydCB7IENoYXJ0QWNjb3VudHMgfSBmcm9tICcuLi8uLi9jaGFydC1hY2NvdW50cy9jaGFydC1hY2NvdW50cyc7XG5cbi8qKlxuICogQ2xhc3Mgd2l0aCB0cmFuc2FjdGlvbi1iYXNlZCBwcm9wZXJ0eSB0cmFuc2FjdGlvbnMgcmVwb3J0IGVudGl0aWVzXG4gKi9cbmV4cG9ydCBjbGFzcyBQcm9wZXJ0eVJlcG9ydEl0ZW1UcmFuc2FjdGlvbiBleHRlbmRzIFByb3BlcnR5UmVwb3J0SXRlbSB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIHRyYW5zYWN0aW9uczogVHJhbnNhY3Rpb25Db2xsZWN0aW9uLFxuICAgIHByb3BlcnR5OiBQcm9wZXJ0eSxcbiAgICBjaGFydEFjY291bnRzOiBDaGFydEFjY291bnRzXG4gICkge1xuICAgIHN1cGVyKHByb3BlcnR5LCBjaGFydEFjY291bnRzKTtcbiAgICB0aGlzLmFtb3VudCA9IE1hdGguYWJzKHRyYW5zYWN0aW9ucy5hbW91bnQpO1xuICAgIHRoaXMuZGVzY3JpcHRpb24gPSBjaGFydEFjY291bnRzLm5hbWVcbiAgfVxufVxuIl19
|
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { Transform, Type } from 'class-transformer';
|
|
3
|
+
import { ReportItemCollection } from '../../collections/tax-summary/report-item.collection';
|
|
1
4
|
/**
|
|
2
5
|
* Used in tax summary reports to show amounts relating to a tax return category entity and details of what this
|
|
3
6
|
* amount is comprised of. Example here shows an amount of $951.96 and also details of what this amount is comprised of:
|
|
@@ -12,4 +15,8 @@ export class ReportItem {
|
|
|
12
15
|
return ((_a = this.details.find((detail) => detail.name === name)) === null || _a === void 0 ? void 0 : _a.amount) || 0;
|
|
13
16
|
}
|
|
14
17
|
}
|
|
15
|
-
|
|
18
|
+
__decorate([
|
|
19
|
+
Type(() => ReportItem),
|
|
20
|
+
Transform(({ value }) => new ReportItemCollection(value))
|
|
21
|
+
], ReportItem.prototype, "items", void 0);
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwb3J0LWl0ZW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dC1jb3JlL3NyYy9saWIvbW9kZWxzL3RheC1zdW1tYXJ5L3JlcG9ydC1pdGVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFFQSxPQUFPLEVBQUUsU0FBUyxFQUFFLElBQUksRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHNEQUFzRCxDQUFDO0FBRTVGOzs7R0FHRztBQUNILE1BQU0sT0FBTyxVQUFVO0lBVXJCOzs7T0FHRztJQUNILDJCQUEyQixDQUFDLElBQVk7O1FBQ3RDLE9BQU8sQ0FBQSxNQUFBLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsTUFBeUIsRUFBVyxFQUFFLENBQUMsTUFBTSxDQUFDLElBQUksS0FBSyxJQUFJLENBQUMsMENBQUUsTUFBTSxLQUFJLENBQUMsQ0FBQztJQUN0RyxDQUFDO0NBQ0Y7QUFUQztJQUZDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxVQUFVLENBQUM7SUFDdEIsU0FBUyxDQUFDLENBQUMsRUFBQyxLQUFLLEVBQUMsRUFBRSxFQUFFLENBQUMsSUFBSSxvQkFBb0IsQ0FBQyxLQUFLLENBQUMsQ0FBQzt5Q0FDNUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUYXhSZXR1cm5DYXRlZ29yeSB9IGZyb20gJy4uLy4uL2RiL01vZGVscy90YXgtcmV0dXJuL3RheC1yZXR1cm4tY2F0ZWdvcnknO1xuaW1wb3J0IHsgUmVwb3J0SXRlbURldGFpbHMgfSBmcm9tICcuL3JlcG9ydC1pdGVtLWRldGFpbHMnO1xuaW1wb3J0IHsgVHJhbnNmb3JtLCBUeXBlIH0gZnJvbSAnY2xhc3MtdHJhbnNmb3JtZXInO1xuaW1wb3J0IHsgUmVwb3J0SXRlbUNvbGxlY3Rpb24gfSBmcm9tICcuLi8uLi9jb2xsZWN0aW9ucy90YXgtc3VtbWFyeS9yZXBvcnQtaXRlbS5jb2xsZWN0aW9uJztcblxuLyoqXG4gKiBVc2VkIGluIHRheCBzdW1tYXJ5IHJlcG9ydHMgdG8gc2hvdyBhbW91bnRzIHJlbGF0aW5nIHRvIGEgdGF4IHJldHVybiBjYXRlZ29yeSBlbnRpdHkgYW5kIGRldGFpbHMgb2Ygd2hhdCB0aGlzXG4gKiBhbW91bnQgaXMgY29tcHJpc2VkIG9mLiBFeGFtcGxlIGhlcmUgc2hvd3MgYW4gYW1vdW50IG9mICQ5NTEuOTYgYW5kIGFsc28gZGV0YWlscyBvZiB3aGF0IHRoaXMgYW1vdW50IGlzIGNvbXByaXNlZCBvZjpcbiAqL1xuZXhwb3J0IGNsYXNzIFJlcG9ydEl0ZW0ge1xuICBhbW91bnQ6IG51bWJlcjtcbiAgZGV0YWlsczogUmVwb3J0SXRlbURldGFpbHNbXTtcbiAgdGF4UmV0dXJuQ2F0ZWdvcnk6IFRheFJldHVybkNhdGVnb3J5O1xuICB0aXRsZTogc3RyaW5nO1xuXG4gIEBUeXBlKCgpID0+IFJlcG9ydEl0ZW0pXG4gIEBUcmFuc2Zvcm0oKHt2YWx1ZX0pID0+IG5ldyBSZXBvcnRJdGVtQ29sbGVjdGlvbih2YWx1ZSkpXG4gIGl0ZW1zOiBSZXBvcnRJdGVtQ29sbGVjdGlvbjtcblxuICAvKipcbiAgICogR2V0IGFtb3VudCBmb3Igb25lIGluY29tZSBzb3VyY2VcbiAgICogQHBhcmFtIG5hbWUgTmFtZSBvZiBpbmNvbWUgc291cmNlIGZvciBmaWx0ZXJcbiAgICovXG4gIGdldEFtb3VudEJ5SW5jb21lU291cmNlTmFtZShuYW1lOiBzdHJpbmcpOiBudW1iZXIge1xuICAgIHJldHVybiB0aGlzLmRldGFpbHMuZmluZCgoZGV0YWlsOiBSZXBvcnRJdGVtRGV0YWlscyk6IGJvb2xlYW4gPT4gZGV0YWlsLm5hbWUgPT09IG5hbWUpPy5hbW91bnQgfHwgMDtcbiAgfVxufVxuIl19
|