taxtank-core 0.28.44 → 0.28.46
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 +474 -14
- package/bundles/taxtank-core.umd.js.map +1 -1
- package/esm2015/lib/collections/tax-summary/tax-return-categories.const.js +4 -1
- package/esm2015/lib/db/Enums/chart-accounts-heading-list.enum.js +20 -1
- package/esm2015/lib/db/Enums/chart-accounts-list.enum.js +35 -2
- package/esm2015/lib/forms/report/my-tax/index.js +5 -2
- package/esm2015/lib/forms/report/my-tax/my-tax-business-income-or-losses/my-tax-business-details/my-tax-business-details.form.js +33 -0
- package/esm2015/lib/forms/report/my-tax/my-tax-business-income-or-losses/my-tax-business-income/my-tax-business-income.form.js +81 -0
- package/esm2015/lib/forms/report/my-tax/my-tax-business-income-or-losses/my-tax-business-income-or-losses.form.js +17 -0
- package/esm2015/lib/forms/report/my-tax/my-tax-business-income-or-losses/my-tax-business-losses/my-tax-business-losses.form.js +76 -0
- package/esm2015/lib/models/report/my-tax/index.js +6 -2
- package/esm2015/lib/models/report/my-tax/my-tax-business-income-or-losses/business-income-or-losses-categories.const.js +27 -0
- package/esm2015/lib/models/report/my-tax/my-tax-business-income-or-losses/business-type.enum.js +11 -0
- package/esm2015/lib/models/report/my-tax/my-tax-business-income-or-losses/loss-type.enum.js +16 -0
- package/esm2015/lib/models/report/my-tax/my-tax-business-income-or-losses/my-tax-business-details/my-tax-business-details.js +15 -0
- package/esm2015/lib/models/report/my-tax/my-tax-business-income-or-losses/my-tax-business-income/my-tax-business-income.js +77 -0
- package/esm2015/lib/models/report/my-tax/my-tax-business-income-or-losses/my-tax-business-losses/my-tax-business-losses.js +70 -0
- package/esm2015/lib/models/tax-summary/tax-summary.js +4 -3
- package/fesm2015/taxtank-core.js +452 -10
- package/fesm2015/taxtank-core.js.map +1 -1
- package/lib/db/Enums/chart-accounts-heading-list.enum.d.ts +20 -1
- package/lib/db/Enums/chart-accounts-list.enum.d.ts +35 -2
- package/lib/forms/report/my-tax/index.d.ts +4 -1
- package/lib/forms/report/my-tax/my-tax-business-income-or-losses/my-tax-business-details/my-tax-business-details.form.d.ts +9 -0
- package/lib/forms/report/my-tax/my-tax-business-income-or-losses/my-tax-business-income/my-tax-business-income.form.d.ts +5 -0
- package/lib/forms/report/my-tax/my-tax-business-income-or-losses/my-tax-business-income-or-losses.form.d.ts +8 -0
- package/lib/forms/report/my-tax/my-tax-business-income-or-losses/my-tax-business-losses/my-tax-business-losses.form.d.ts +5 -0
- package/lib/models/report/my-tax/index.d.ts +5 -1
- package/lib/models/report/my-tax/my-tax-business-income-or-losses/business-income-or-losses-categories.const.d.ts +8 -0
- package/lib/models/report/my-tax/my-tax-business-income-or-losses/business-type.enum.d.ts +9 -0
- package/lib/models/report/my-tax/my-tax-business-income-or-losses/loss-type.enum.d.ts +14 -0
- package/lib/models/report/my-tax/my-tax-business-income-or-losses/my-tax-business-details/my-tax-business-details.d.ts +16 -0
- package/lib/models/report/my-tax/my-tax-business-income-or-losses/my-tax-business-income/my-tax-business-income.d.ts +29 -0
- package/lib/models/report/my-tax/my-tax-business-income-or-losses/my-tax-business-losses/my-tax-business-losses.d.ts +30 -0
- package/package.json +1 -1
- package/esm2015/lib/forms/report/my-tax/my-tax-business-or-losses.form.js +0 -10
- package/esm2015/lib/models/report/my-tax/my-tax-business-or-losses/my-tax-business-or-losses.js +0 -8
- package/lib/forms/report/my-tax/my-tax-business-or-losses.form.d.ts +0 -8
- package/lib/models/report/my-tax/my-tax-business-or-losses/my-tax-business-or-losses.d.ts +0 -7
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import { ChartAccountsListEnum } from '../../../../../db/Enums/chart-accounts-list.enum';
|
|
2
|
+
import { BUSINESS_INCOME_OR_LOSSES_CATEGORIES } from '../business-income-or-losses-categories.const';
|
|
3
|
+
import { ChartAccountsCategoryEnum } from '../../../../../db/Enums/chart-accounts-category.enum';
|
|
4
|
+
import { ChartAccountsHeadingListEnum } from '../../../../../db/Enums/chart-accounts-heading-list.enum';
|
|
5
|
+
/**
|
|
6
|
+
* Sole business information related to income transactions
|
|
7
|
+
* https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/4644110466/Tax+Return+MyTax+-+Online+Form (section "Business income or losses")
|
|
8
|
+
*/
|
|
9
|
+
export class MyTaxBusinessIncome {
|
|
10
|
+
constructor(psiIncome, soleIncome) {
|
|
11
|
+
this.psiIncomeAmount = psiIncome.filterBy('chartAccounts.heading.id', ChartAccountsHeadingListEnum.PSI).amount;
|
|
12
|
+
this.psiVoluntaryAgreementAmount = psiIncome
|
|
13
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.PSI_VOLUNTARY_AGREEMENT)
|
|
14
|
+
.amount;
|
|
15
|
+
this.psiABNNotQuotedAmount = psiIncome
|
|
16
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.PSI_ABN_NOT_QUOTED)
|
|
17
|
+
.amount;
|
|
18
|
+
this.psiLabourHireOrOtherAmount = psiIncome
|
|
19
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.PSI_LABOUR_HIRE_OR_OTHER)
|
|
20
|
+
.amount;
|
|
21
|
+
this.psiOtherAmount = psiIncome
|
|
22
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.PSI_OTHER)
|
|
23
|
+
.amount;
|
|
24
|
+
this.psiDeductionAssociatesAmount = psiIncome
|
|
25
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.PSI_DEDUCTION_ASSOCIATES)
|
|
26
|
+
.amount;
|
|
27
|
+
this.psiDeductionOtherAmount = psiIncome
|
|
28
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.PSI_DEDUCTION_OTHER)
|
|
29
|
+
.amount;
|
|
30
|
+
this.netPSIAmount = psiIncome
|
|
31
|
+
.filterBy('chartAccounts.id', BUSINESS_INCOME_OR_LOSSES_CATEGORIES.psiIncomes)
|
|
32
|
+
.amount -
|
|
33
|
+
psiIncome
|
|
34
|
+
.filterBy('chartAccounts.id', BUSINESS_INCOME_OR_LOSSES_CATEGORIES.psiDeductions)
|
|
35
|
+
.amount;
|
|
36
|
+
this.psiVoluntaryAgreementTax = psiIncome
|
|
37
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.PSI_VOLUNTARY_AGREEMENT)
|
|
38
|
+
.sumBy('tax');
|
|
39
|
+
this.psiABNNotQuotedTax = psiIncome
|
|
40
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.PSI_ABN_NOT_QUOTED)
|
|
41
|
+
.sumBy('tax');
|
|
42
|
+
this.psiLabourHireOrOtherTax = psiIncome
|
|
43
|
+
.filterBy('chartAccounts.id', [ChartAccountsListEnum.PSI_LABOUR_HIRE_OR_OTHER, ChartAccountsListEnum.PSI_OTHER])
|
|
44
|
+
.sumBy('tax');
|
|
45
|
+
this.netPSITax = psiIncome
|
|
46
|
+
.filterBy('chartAccounts.id', BUSINESS_INCOME_OR_LOSSES_CATEGORIES.psiIncomes)
|
|
47
|
+
.sumBy('tax');
|
|
48
|
+
this.grossPaymentsNoAbsGivenAmount = soleIncome
|
|
49
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.GROSS_PAYMENTS_NO_ABN_GIVEN)
|
|
50
|
+
.amount;
|
|
51
|
+
this.grossPaymentsVoluntaryAgreementAmount = soleIncome
|
|
52
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.GROSS_PAYMENTS_VOLUNTARY_AGREEMENT)
|
|
53
|
+
.amount;
|
|
54
|
+
this.grossPaymentsLabourHireAmount = soleIncome
|
|
55
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.GROSS_PAYMENTS_LABOUR_HIRE_OR_OTHER_SPECIFIED_PAYMENTS)
|
|
56
|
+
.amount;
|
|
57
|
+
this.assessibleGovernmentPaymentsAmount = soleIncome
|
|
58
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.ASSESSIBLE_GOVERNMENT_PAYMENTS)
|
|
59
|
+
.amount;
|
|
60
|
+
this.otherBusinessIncomeAmount = soleIncome
|
|
61
|
+
.filterBy('chartAccounts.id', BUSINESS_INCOME_OR_LOSSES_CATEGORIES.otherBusinessIncome)
|
|
62
|
+
.amount;
|
|
63
|
+
this.nonPrimaryProductionTotalAmount = soleIncome
|
|
64
|
+
.filterBy('chartAccounts.category', ChartAccountsCategoryEnum.SOLE_INCOME)
|
|
65
|
+
.amount;
|
|
66
|
+
this.grossPaymentsNoAbsGivenTax = soleIncome
|
|
67
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.GROSS_PAYMENTS_NO_ABN_GIVEN)
|
|
68
|
+
.sumBy('tax');
|
|
69
|
+
this.grossPaymentsVoluntaryAgreementTax = soleIncome
|
|
70
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.GROSS_PAYMENTS_VOLUNTARY_AGREEMENT)
|
|
71
|
+
.sumBy('tax');
|
|
72
|
+
this.grossPaymentsLabourHireTax = soleIncome
|
|
73
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.GROSS_PAYMENTS_LABOUR_HIRE_OR_OTHER_SPECIFIED_PAYMENTS)
|
|
74
|
+
.sumBy('tax');
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"my-tax-business-income.js","sourceRoot":"","sources":["../../../../../../../../../projects/tt-core/src/lib/models/report/my-tax/my-tax-business-income-or-losses/my-tax-business-income/my-tax-business-income.ts"],"names":[],"mappings":"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","sourcesContent":["import { TransactionCollection } from '../../../../../collections/transaction/transaction.collection';\nimport { ChartAccountsListEnum } from '../../../../../db/Enums/chart-accounts-list.enum';\nimport { BUSINESS_INCOME_OR_LOSSES_CATEGORIES } from '../business-income-or-losses-categories.const';\nimport { ChartAccountsCategoryEnum } from '../../../../../db/Enums/chart-accounts-category.enum';\nimport { ChartAccountsHeadingListEnum } from '../../../../../db/Enums/chart-accounts-heading-list.enum';\n\n/**\n * Sole business information related to income transactions\n * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/4644110466/Tax+Return+MyTax+-+Online+Form (section \"Business income or losses\")\n */\nexport class MyTaxBusinessIncome {\n  psiIncomeAmount: number;\n  psiVoluntaryAgreementAmount: number;\n  psiABNNotQuotedAmount: number;\n  psiLabourHireOrOtherAmount: number;\n  psiOtherAmount: number;\n  psiDeductionAssociatesAmount: number;\n  psiDeductionOtherAmount: number;\n  netPSIAmount: number;\n  psiVoluntaryAgreementTax: number;\n  psiABNNotQuotedTax: number;\n  psiLabourHireOrOtherTax: number;\n  netPSITax: number;\n  grossPaymentsNoAbsGivenAmount: number;\n  grossPaymentsVoluntaryAgreementAmount: number;\n  grossPaymentsLabourHireAmount: number;\n  grossPaymentsNoAbsGivenTax: number;\n  grossPaymentsVoluntaryAgreementTax: number;\n  grossPaymentsLabourHireTax: number;\n  assessibleGovernmentPaymentsAmount: number;\n  otherBusinessIncomeAmount: number;\n  nonPrimaryProductionTotalAmount: number;\n\n  constructor(\n    psiIncome: TransactionCollection,\n    soleIncome: TransactionCollection,\n  ) {\n    this.psiIncomeAmount = psiIncome.filterBy('chartAccounts.heading.id', ChartAccountsHeadingListEnum.PSI).amount;\n    this.psiVoluntaryAgreementAmount = psiIncome\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.PSI_VOLUNTARY_AGREEMENT)\n      .amount;\n    this.psiABNNotQuotedAmount = psiIncome\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.PSI_ABN_NOT_QUOTED)\n      .amount;\n    this.psiLabourHireOrOtherAmount = psiIncome\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.PSI_LABOUR_HIRE_OR_OTHER)\n      .amount;\n    this.psiOtherAmount = psiIncome\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.PSI_OTHER)\n      .amount;\n    this.psiDeductionAssociatesAmount = psiIncome\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.PSI_DEDUCTION_ASSOCIATES)\n      .amount;\n    this.psiDeductionOtherAmount = psiIncome\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.PSI_DEDUCTION_OTHER)\n      .amount;\n    this.netPSIAmount = psiIncome\n        .filterBy('chartAccounts.id', BUSINESS_INCOME_OR_LOSSES_CATEGORIES.psiIncomes)\n        .amount -\n      psiIncome\n        .filterBy('chartAccounts.id', BUSINESS_INCOME_OR_LOSSES_CATEGORIES.psiDeductions)\n        .amount;\n    this.psiVoluntaryAgreementTax = psiIncome\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.PSI_VOLUNTARY_AGREEMENT)\n      .sumBy('tax');\n    this.psiABNNotQuotedTax = psiIncome\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.PSI_ABN_NOT_QUOTED)\n      .sumBy('tax');\n    this.psiLabourHireOrOtherTax = psiIncome\n      .filterBy('chartAccounts.id', [ChartAccountsListEnum.PSI_LABOUR_HIRE_OR_OTHER, ChartAccountsListEnum.PSI_OTHER])\n      .sumBy('tax');\n    this.netPSITax = psiIncome\n      .filterBy('chartAccounts.id', BUSINESS_INCOME_OR_LOSSES_CATEGORIES.psiIncomes)\n      .sumBy('tax');\n\n    this.grossPaymentsNoAbsGivenAmount = soleIncome\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.GROSS_PAYMENTS_NO_ABN_GIVEN)\n      .amount;\n    this.grossPaymentsVoluntaryAgreementAmount = soleIncome\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.GROSS_PAYMENTS_VOLUNTARY_AGREEMENT)\n      .amount;\n    this.grossPaymentsLabourHireAmount = soleIncome\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.GROSS_PAYMENTS_LABOUR_HIRE_OR_OTHER_SPECIFIED_PAYMENTS)\n      .amount;\n    this.assessibleGovernmentPaymentsAmount = soleIncome\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.ASSESSIBLE_GOVERNMENT_PAYMENTS)\n      .amount;\n    this.otherBusinessIncomeAmount = soleIncome\n      .filterBy('chartAccounts.id', BUSINESS_INCOME_OR_LOSSES_CATEGORIES.otherBusinessIncome)\n      .amount;\n    this.nonPrimaryProductionTotalAmount = soleIncome\n      .filterBy('chartAccounts.category', ChartAccountsCategoryEnum.SOLE_INCOME)\n      .amount;\n    this.grossPaymentsNoAbsGivenTax = soleIncome\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.GROSS_PAYMENTS_NO_ABN_GIVEN)\n      .sumBy('tax');\n    this.grossPaymentsVoluntaryAgreementTax = soleIncome\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.GROSS_PAYMENTS_VOLUNTARY_AGREEMENT)\n      .sumBy('tax');\n    this.grossPaymentsLabourHireTax = soleIncome\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.GROSS_PAYMENTS_LABOUR_HIRE_OR_OTHER_SPECIFIED_PAYMENTS)\n      .sumBy('tax');\n  }\n}\n"]}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { ChartAccountsHeadingListEnum } from '../../../../../db/Enums/chart-accounts-heading-list.enum';
|
|
2
|
+
import { ChartAccountsListEnum } from '../../../../../db/Enums/chart-accounts-list.enum';
|
|
3
|
+
import { ChartAccountsCategoryEnum } from '../../../../../db/Enums/chart-accounts-category.enum';
|
|
4
|
+
/**
|
|
5
|
+
* Sole business information related to expense transactions (losses)
|
|
6
|
+
* https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/4644110466/Tax+Return+MyTax+-+Online+Form (section "Business income or losses")
|
|
7
|
+
*/
|
|
8
|
+
export class MyTaxBusinessLosses {
|
|
9
|
+
constructor(transactions, depreciations, businessLosses, currentLoss) {
|
|
10
|
+
this.currentLoss = currentLoss;
|
|
11
|
+
this.purchasesAndOtherCostsAmount = Math.abs(transactions.getExpenseTransactions()
|
|
12
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.PURCHASES_STOCK_INVENTORY)
|
|
13
|
+
.sumBy('claimAmount'));
|
|
14
|
+
this.contractorsAndCommissionAmount = Math.abs(transactions.getExpenseTransactions()
|
|
15
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.CONTRACTORS_AND_COMMISSION)
|
|
16
|
+
.sumBy('claimAmount'));
|
|
17
|
+
this.superannuationAmount = Math.abs(transactions.getExpenseTransactions()
|
|
18
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.SUPERANNUATION)
|
|
19
|
+
.sumBy('claimAmount'));
|
|
20
|
+
this.badDebtAmount = Math.abs(transactions.getExpenseTransactions()
|
|
21
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.BAD_DEBT)
|
|
22
|
+
.sumBy('claimAmount'));
|
|
23
|
+
this.leaseExpensesCommercialAmount = Math.abs(transactions.getExpenseTransactions()
|
|
24
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.LEASE_EXPENSES_COMMERCIAL)
|
|
25
|
+
.sumBy('claimAmount'));
|
|
26
|
+
this.rentExpensesCommercialPremisesAmount = Math.abs(transactions.getExpenseTransactions()
|
|
27
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.RENT_EXPENSES_COMMERCIAL_PREMISES)
|
|
28
|
+
.sumBy('claimAmount'));
|
|
29
|
+
this.interestExpensesAustraliaAmount = Math.abs(transactions.getExpenseTransactions()
|
|
30
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.INTEREST_EXPENSES_AUSTRALIA)
|
|
31
|
+
.sumBy('claimAmount'));
|
|
32
|
+
this.interestExpensesOverseasAmount = Math.abs(transactions.getExpenseTransactions()
|
|
33
|
+
.filterBy('chartAccounts.id', ChartAccountsListEnum.INTEREST_EXPENSES_OVERSEAS)
|
|
34
|
+
.sumBy('claimAmount'));
|
|
35
|
+
this.kmsTravelledExpensesAmount = Math.abs(transactions
|
|
36
|
+
.filterBy('chartAccounts.heading.id', [ChartAccountsHeadingListEnum.WORK_RELATED_CAR_EXPENSES, ChartAccountsHeadingListEnum.DEPRECIATION_VEHICLES])
|
|
37
|
+
.sumBy('claimAmount'));
|
|
38
|
+
this.otherExpensesAmount = Math.abs(transactions
|
|
39
|
+
.filterBy('chartAccounts.heading.id', ChartAccountsHeadingListEnum.OTHER_EXPENSES)
|
|
40
|
+
.sumBy('claimAmount'));
|
|
41
|
+
this.totalNonPrimaryProductionExpensesAmount = Math.abs(transactions
|
|
42
|
+
.filterBy('chartAccounts.category', [ChartAccountsCategoryEnum.SOLE_EXPENSE, ChartAccountsCategoryEnum.SOLE_DEPRECIATION])
|
|
43
|
+
.sumBy('claimAmount'));
|
|
44
|
+
// depreciations
|
|
45
|
+
this.depreciationExpensesAmount = depreciations
|
|
46
|
+
.filterBy('chartAccounts.heading.id', ChartAccountsHeadingListEnum.DEPRECIATION_EXPENSES)
|
|
47
|
+
.sumBy('claimAmount');
|
|
48
|
+
this.deductionsForCertainAssetsAmount = depreciations
|
|
49
|
+
.getWrittenOffDepreciations()
|
|
50
|
+
.sumBy('claimAmount');
|
|
51
|
+
this.deductionsForGeneralSmallBusinessPoolAmount = depreciations
|
|
52
|
+
.getSBPDepreciations()
|
|
53
|
+
.sumBy('claimAmount');
|
|
54
|
+
this.currentYearNetNonPrimaryIncomeOrLossesAmount = transactions.getIncomeTransactions()
|
|
55
|
+
.filterBy('chartAccounts.category', ChartAccountsCategoryEnum.SOLE_INCOME)
|
|
56
|
+
.amount -
|
|
57
|
+
Math.abs(transactions
|
|
58
|
+
.filterBy('chartAccounts.category', [ChartAccountsCategoryEnum.SOLE_EXPENSE, ChartAccountsCategoryEnum.SOLE_DEPRECIATION])
|
|
59
|
+
.sumBy('claimAmount'));
|
|
60
|
+
this.priorYearsNonPrimaryLossesAmount = this.calculatePriorYearsOpenBalance(businessLosses);
|
|
61
|
+
this.netNonPrimaryIncomeOrLossesAmount = transactions.getIncomeTransactions()
|
|
62
|
+
.filterBy('chartAccounts.category', ChartAccountsCategoryEnum.SOLE_INCOME)
|
|
63
|
+
.amount -
|
|
64
|
+
this.priorYearsNonPrimaryLossesAmount;
|
|
65
|
+
}
|
|
66
|
+
calculatePriorYearsOpenBalance(businessLosses) {
|
|
67
|
+
return businessLosses ? businessLosses.sumBy('openBalance') : 0;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"my-tax-business-losses.js","sourceRoot":"","sources":["../../../../../../../../../projects/tt-core/src/lib/models/report/my-tax/my-tax-business-income-or-losses/my-tax-business-losses/my-tax-business-losses.ts"],"names":[],"mappings":"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","sourcesContent":["import { TransactionCollection } from '../../../../../collections/transaction/transaction.collection';\nimport { ChartAccountsHeadingListEnum } from '../../../../../db/Enums/chart-accounts-heading-list.enum';\nimport { DepreciationCollection } from '../../../../../collections/depreciation.collection';\nimport { ChartAccountsListEnum } from '../../../../../db/Enums/chart-accounts-list.enum';\nimport { ChartAccountsCategoryEnum } from '../../../../../db/Enums/chart-accounts-category.enum';\nimport { Collection } from '../../../../../collections/collection';\nimport { SoleBusinessLoss } from '../../../../sole';\n\n/**\n * Sole business information related to expense transactions (losses)\n * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/4644110466/Tax+Return+MyTax+-+Online+Form (section \"Business income or losses\")\n */\nexport class MyTaxBusinessLosses {\n  currentLoss: SoleBusinessLoss;\n  purchasesAndOtherCostsAmount: number;\n  contractorsAndCommissionAmount: number;\n  superannuationAmount: number;\n  badDebtAmount: number;\n  leaseExpensesCommercialAmount: number;\n  rentExpensesCommercialPremisesAmount: number;\n  interestExpensesAustraliaAmount: number;\n  interestExpensesOverseasAmount: number;\n  kmsTravelledExpensesAmount: number;\n  otherExpensesAmount: number;\n  totalNonPrimaryProductionExpensesAmount: number;\n  depreciationExpensesAmount: number;\n  deductionsForCertainAssetsAmount: number;\n  deductionsForGeneralSmallBusinessPoolAmount: number;\n  priorYearsNonPrimaryLossesAmount: number;\n  netNonPrimaryIncomeOrLossesAmount: number;\n  currentYearNetNonPrimaryIncomeOrLossesAmount: number;\n\n  constructor(\n    transactions: TransactionCollection,\n    depreciations: DepreciationCollection,\n    businessLosses: Collection<SoleBusinessLoss>,\n    currentLoss: SoleBusinessLoss\n  ) {\n    this.currentLoss = currentLoss;\n    this.purchasesAndOtherCostsAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.PURCHASES_STOCK_INVENTORY)\n      .sumBy('claimAmount'));\n    this.contractorsAndCommissionAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.CONTRACTORS_AND_COMMISSION)\n      .sumBy('claimAmount'));\n    this.superannuationAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.SUPERANNUATION)\n      .sumBy('claimAmount'));\n    this.badDebtAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.BAD_DEBT)\n      .sumBy('claimAmount'));\n    this.leaseExpensesCommercialAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.LEASE_EXPENSES_COMMERCIAL)\n      .sumBy('claimAmount'));\n    this.rentExpensesCommercialPremisesAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.RENT_EXPENSES_COMMERCIAL_PREMISES)\n      .sumBy('claimAmount'));\n    this.interestExpensesAustraliaAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.INTEREST_EXPENSES_AUSTRALIA)\n      .sumBy('claimAmount'));\n    this.interestExpensesOverseasAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.INTEREST_EXPENSES_OVERSEAS)\n      .sumBy('claimAmount'));\n    this.kmsTravelledExpensesAmount = Math.abs(transactions\n      .filterBy('chartAccounts.heading.id', [ChartAccountsHeadingListEnum.WORK_RELATED_CAR_EXPENSES, ChartAccountsHeadingListEnum.DEPRECIATION_VEHICLES])\n      .sumBy('claimAmount'));\n    this.otherExpensesAmount = Math.abs(transactions\n      .filterBy('chartAccounts.heading.id', ChartAccountsHeadingListEnum.OTHER_EXPENSES)\n      .sumBy('claimAmount'));\n    this.totalNonPrimaryProductionExpensesAmount = Math.abs(transactions\n      .filterBy('chartAccounts.category', [ChartAccountsCategoryEnum.SOLE_EXPENSE, ChartAccountsCategoryEnum.SOLE_DEPRECIATION])\n      .sumBy('claimAmount'));\n    // depreciations\n    this.depreciationExpensesAmount = depreciations\n      .filterBy('chartAccounts.heading.id', ChartAccountsHeadingListEnum.DEPRECIATION_EXPENSES)\n      .sumBy('claimAmount');\n    this.deductionsForCertainAssetsAmount = depreciations\n      .getWrittenOffDepreciations()\n      .sumBy('claimAmount');\n    this.deductionsForGeneralSmallBusinessPoolAmount = depreciations\n      .getSBPDepreciations()\n      .sumBy('claimAmount');\n    this.currentYearNetNonPrimaryIncomeOrLossesAmount = transactions.getIncomeTransactions()\n        .filterBy('chartAccounts.category', ChartAccountsCategoryEnum.SOLE_INCOME)\n        .amount -\n      Math.abs(transactions\n        .filterBy('chartAccounts.category', [ChartAccountsCategoryEnum.SOLE_EXPENSE, ChartAccountsCategoryEnum.SOLE_DEPRECIATION])\n        .sumBy('claimAmount'));\n    this.priorYearsNonPrimaryLossesAmount = this.calculatePriorYearsOpenBalance(businessLosses);\n    this.netNonPrimaryIncomeOrLossesAmount = transactions.getIncomeTransactions()\n        .filterBy('chartAccounts.category', ChartAccountsCategoryEnum.SOLE_INCOME)\n        .amount -\n      this.priorYearsNonPrimaryLossesAmount;\n  }\n\n  private calculatePriorYearsOpenBalance(businessLosses: Collection<SoleBusinessLoss>): number {\n    return businessLosses ? businessLosses.sumBy('openBalance') : 0;\n  }\n}\n"]}
|
|
@@ -94,9 +94,10 @@ export class TaxSummary {
|
|
|
94
94
|
get soleNetTotal() {
|
|
95
95
|
const income = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.income);
|
|
96
96
|
const expenses = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.expenses);
|
|
97
|
-
const depreciation = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.
|
|
97
|
+
const depreciation = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.depreciation);
|
|
98
98
|
const loss = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.loss);
|
|
99
|
-
|
|
99
|
+
const lossCurrent = this.sole.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.sole.lossCurrent, TaxSummarySectionEnum.SOLE_TANK);
|
|
100
|
+
return income + expenses + depreciation + loss + lossCurrent;
|
|
100
101
|
}
|
|
101
102
|
}
|
|
102
103
|
__decorate([
|
|
@@ -114,4 +115,4 @@ __decorate([
|
|
|
114
115
|
__decorate([
|
|
115
116
|
Type(() => TaxSummarySection)
|
|
116
117
|
], TaxSummary.prototype, "summary", void 0);
|
|
117
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tax-summary.js","sourceRoot":"","sources":["../../../../../../projects/tt-core/src/lib/models/tax-summary/tax-summary.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAC;AACzC,OAAO,EAAE,qBAAqB,EAAE,MAAM,2DAA2D,CAAC;AAClG,OAAO,EAAE,yBAAyB,EAAE,MAAM,8CAA8C,CAAC;AACzF,OAAO,EAAE,qBAAqB,EAAE,MAAM,yCAAyC,CAAC;AAEhF;;;GAGG;AACH,MAAM,OAAO,UAAU;IAkBrB,IAAI,QAAQ;QACV,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;IACzE,CAAC;IAED,IAAI,UAAU;QACZ,wDAAwD;QACxD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE;YAC3B,OAAO,CAAC,CAAC;SACV;QAED,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,cAAc,CAAC,yBAAyB,CAAC,iBAAiB,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;IACxH,CAAC;IAED;;;OAGG;IACH,IAAI,WAAW;QACb,MAAM,WAAW,GAAW,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,IAAI,CAAC,WAAW,EAAE,qBAAqB,CAAC,SAAS,CAAC,CAAC;QAElJ,OAAO,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;IACnD,CAAC;IAED;;;OAGG;IACH,IAAI,YAAY;QACd,MAAM,MAAM,GAAW,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,IAAI,CAAC,MAAM,EAAE,qBAAqB,CAAC,SAAS,CAAC,CAAC;QACrI,MAAM,QAAQ,GAAW,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,qBAAqB,CAAC,SAAS,CAAC,CAAC;QACzI,MAAM,QAAQ,GAAW,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,qBAAqB,CAAC,SAAS,CAAC,CAAC;QAE5I,OAAO,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAC1D,CAAC;IAED;;;OAGG;IACH,IAAI,eAAe;QACjB,MAAM,MAAM,GAAW,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,QAAQ,CAAC,MAAM,EAAE,qBAAqB,CAAC,aAAa,CAAC,CAAC;QACjJ,MAAM,QAAQ,GAAW,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,QAAQ,CAAC,QAAQ,EAAE,qBAAqB,CAAC,aAAa,CAAC,CAAC;QACrJ,MAAM,QAAQ,GAAW,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,QAAQ,CAAC,QAAQ,EAAE,qBAAqB,CAAC,aAAa,CAAC,CAAC;QAErJ,OAAO,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAC1D,CAAC;IAED;;;OAGG;IACH,IAAI,gBAAgB;QAClB,MAAM,YAAY,GAAW,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,QAAQ,CAAC,YAAY,EAAE,qBAAqB,CAAC,aAAa,CAAC,CAAC;QAE7J,OAAO,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;IACvD,CAAC;IAED;;;OAGG;IACH,IAAI,YAAY;QACd,MAAM,MAAM,GAAW,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,KAAK,CAAC,MAAM,EAAE,qBAAqB,CAAC,UAAU,CAAC,CAAC;QACxI,MAAM,QAAQ,GAAW,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,KAAK,CAAC,QAAQ,EAAE,qBAAqB,CAAC,UAAU,CAAC,CAAC;QAC5I,MAAM,WAAW,GAAW,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,yBAAyB,CAAC,CAAC,yBAAyB,CAAC,YAAY,CAAC,EAAE,qBAAqB,CAAC,UAAU,CAAC,CAAC;QACrJ,MAAM,cAAc,GAAW,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,yBAAyB,CAAC,CAAC,yBAAyB,CAAC,eAAe,CAAC,EAAE,qBAAqB,CAAC,UAAU,CAAC,CAAC;QAE3J,OAAO,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;IACxF,CAAC;IAED;;;OAGG;IACH,IAAI,aAAa;QACf,MAAM,MAAM,GAAW,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,KAAK,CAAC,MAAM,EAAE,qBAAqB,CAAC,UAAU,CAAC,CAAC;QACxI,MAAM,QAAQ,GAAW,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,KAAK,CAAC,QAAQ,EAAE,qBAAqB,CAAC,UAAU,CAAC,CAAC;QAC5I,MAAM,UAAU,GAAW,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,yBAAyB,CAAC,CAAC,yBAAyB,CAAC,WAAW,CAAC,EAAE,qBAAqB,CAAC,OAAO,CAAC,CAAC;QAChJ,MAAM,eAAe,GAAW,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,yBAAyB,CAAC,CAAC,yBAAyB,CAAC,eAAe,CAAC,EAAE,qBAAqB,CAAC,UAAU,CAAC,CAAC;QAC5J,MAAM,eAAe,GAAW,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,yBAAyB,CAAC,CAAC,yBAAyB,CAAC,gBAAgB,CAAC,EAAE,qBAAqB,CAAC,UAAU,CAAC,CAAC;QAE7J,OAAO,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,eAAe,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;IACpH,CAAC;IAED;;;OAGG;IACH,IAAI,WAAW;QACb,MAAM,MAAM,GAAW,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,IAAI,CAAC,MAAM,EAAE,qBAAqB,CAAC,SAAS,CAAC,CAAC;QACrI,MAAM,QAAQ,GAAW,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,qBAAqB,CAAC,SAAS,CAAC,CAAC;QAEzI,OAAO,MAAM,GAAG,QAAQ,CAAC;IAC3B,CAAC;IAED;;;OAGG;IACH,IAAI,YAAY;QACd,MAAM,MAAM,GAAW,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,qBAAqB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC1F,MAAM,QAAQ,GAAW,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC9F,MAAM,YAAY,GAAW,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClG,MAAM,IAAI,GAAW,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEtF,OAAO,MAAM,GAAG,QAAQ,GAAG,YAAY,GAAG,IAAI,CAAC;IACjD,CAAC;CACF;AA3HC;IADC,IAAI,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;wCACN;AAGxB;IADC,IAAI,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;4CACF;AAG5B;IADC,IAAI,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;yCACL;AAGzB;IADC,IAAI,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;wCACN;AAGxB;IADC,IAAI,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;2CACH","sourcesContent":["import { TaxSummarySection } from './tax-summary-section';\nimport { Type } from 'class-transformer';\nimport { TAX_RETURN_CATEGORIES } from '../../collections/tax-summary/tax-return-categories.const';\nimport { TaxReturnCategoryListEnum } from '../../db/Enums/tax-return-category-list.enum';\nimport { TaxSummarySectionEnum } from '../../db/Enums/tax-summary-section.enum';\n\n/**\n * @Todo refactor with base model when it will be provided\n * Tax summary report structure\n */\nexport class TaxSummary {\n  @Type(() => TaxSummarySection)\n  work: TaxSummarySection;\n\n  @Type(() => TaxSummarySection)\n  property: TaxSummarySection;\n\n  @Type(() => TaxSummarySection)\n  other: TaxSummarySection;\n\n  @Type(() => TaxSummarySection)\n  sole: TaxSummarySection;\n\n  @Type(() => TaxSummarySection)\n  summary: TaxSummarySection;\n\n  projectedTaxPosition: number;\n\n  get sections(): TaxSummarySection[] {\n    return [this.work, this.property, this.other, this.sole, this.summary];\n  }\n\n  get taxPercent(): number {\n    // Check if netAmount is not 0 to avoid division by zero\n    if (!this.summary.netAmount) {\n      return 0;\n    }\n\n    return this.summary.items.findByCategory(TaxReturnCategoryListEnum.GROSS_TAX_PAYABLE).amount / this.summary.netAmount;\n  }\n\n  /**\n   * Work Net Cash = Income - tax withheld - expenses - interest\n   * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main\n   */\n  get workNetCash(): number {\n    const taxWithheld: number = this.summary.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.work.taxWithheld, TaxSummarySectionEnum.WORK_TANK);\n\n    return this.workNetTotal - Math.abs(taxWithheld);\n  }\n\n  /**\n   * Work Net Total = Income - expenses - interest\n   * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main\n   */\n  get workNetTotal(): number {\n    const income: number = this.work.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.work.income, TaxSummarySectionEnum.WORK_TANK);\n    const expenses: number = this.work.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.work.expenses, TaxSummarySectionEnum.WORK_TANK);\n    const interest: number = this.summary.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.work.interest, TaxSummarySectionEnum.WORK_TANK);\n\n    return income - Math.abs(expenses) - Math.abs(interest);\n  }\n\n  /**\n   * Property Net Cash (Cash Position) = Rental Income - expenses - interest\n   * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main\n   */\n  get propertyNetCash(): number {\n    const income: number = this.property.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.property.income, TaxSummarySectionEnum.PROPERTY_TANK);\n    const expenses: number = this.property.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.property.expenses, TaxSummarySectionEnum.PROPERTY_TANK);\n    const interest: number = this.property.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.property.interest, TaxSummarySectionEnum.PROPERTY_TANK);\n\n    return income - Math.abs(expenses) - Math.abs(interest);\n  }\n\n  /**\n   * Property Net Total (Tax Position) = Rental Income - expenses - interest - depreciation\n   * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main\n   */\n  get propertyNetTotal(): number {\n    const depreciation: number = this.property.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.property.depreciation, TaxSummarySectionEnum.PROPERTY_TANK);\n\n    return this.propertyNetCash - Math.abs(depreciation);\n  }\n\n  /**\n   * Other Net Cash = gross income – expenses – tax withheld - tax instalments\n   * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main\n   */\n  get otherNetCash(): number {\n    const income: number = this.other.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.other.income, TaxSummarySectionEnum.OTHER_TANK);\n    const expenses: number = this.other.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.other.expenses, TaxSummarySectionEnum.OTHER_TANK);\n    const taxWithheld: number = this.summary.items.sumByCategoriesAndSection([TaxReturnCategoryListEnum.TAX_WITHHELD], TaxSummarySectionEnum.OTHER_TANK);\n    const taxInstalments: number = this.summary.items.sumByCategoriesAndSection([TaxReturnCategoryListEnum.TAX_INSTALMENTS], TaxSummarySectionEnum.OTHER_TANK);\n\n    return income - Math.abs(expenses) - Math.abs(taxWithheld) - Math.abs(taxInstalments);\n  }\n\n  /**\n   * Other Net Total = Gross income - expenses + tax offsets + tax instalments + franking credits\n   * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main\n   */\n  get otherNetTotal(): number {\n    const income: number = this.other.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.other.income, TaxSummarySectionEnum.OTHER_TANK);\n    const expenses: number = this.other.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.other.expenses, TaxSummarySectionEnum.OTHER_TANK);\n    const taxOffsets: number = this.summary.items.sumByCategoriesAndSection([TaxReturnCategoryListEnum.TAX_OFFSETS], TaxSummarySectionEnum.SUMMARY);\n    const taxInstallments: number = this.summary.items.sumByCategoriesAndSection([TaxReturnCategoryListEnum.TAX_INSTALMENTS], TaxSummarySectionEnum.OTHER_TANK);\n    const frankingCredits: number = this.summary.items.sumByCategoriesAndSection([TaxReturnCategoryListEnum.FRANKING_CREDITS], TaxSummarySectionEnum.OTHER_TANK);\n\n    return income - Math.abs(expenses) + Math.abs(taxOffsets) + Math.abs(taxInstallments) + Math.abs(frankingCredits);\n  }\n\n  /**\n   * Sole Net Cash = gross income – expenses\n   * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main\n   */\n  get soleNetCash(): number {\n    const income: number = this.sole.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.sole.income, TaxSummarySectionEnum.SOLE_TANK);\n    const expenses: number = this.sole.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.sole.expenses, TaxSummarySectionEnum.SOLE_TANK);\n\n    return income + expenses;\n  }\n\n  /**\n   * Sole Net Total = Gross income - expenses\n   * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main\n   */\n  get soleNetTotal(): number {\n    const income: number = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.income);\n    const expenses: number = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.expenses);\n    const depreciation: number = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.expenses);\n    const loss: number = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.loss);\n\n    return income + expenses + depreciation - loss;\n  }\n}\n"]}
|
|
118
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tax-summary.js","sourceRoot":"","sources":["../../../../../../projects/tt-core/src/lib/models/tax-summary/tax-summary.ts"],"names":[],"mappings":"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","sourcesContent":["import { TaxSummarySection } from './tax-summary-section';\nimport { Type } from 'class-transformer';\nimport { TAX_RETURN_CATEGORIES } from '../../collections/tax-summary/tax-return-categories.const';\nimport { TaxReturnCategoryListEnum } from '../../db/Enums/tax-return-category-list.enum';\nimport { TaxSummarySectionEnum } from '../../db/Enums/tax-summary-section.enum';\n\n/**\n * @Todo refactor with base model when it will be provided\n * Tax summary report structure\n */\nexport class TaxSummary {\n  @Type(() => TaxSummarySection)\n  work: TaxSummarySection;\n\n  @Type(() => TaxSummarySection)\n  property: TaxSummarySection;\n\n  @Type(() => TaxSummarySection)\n  other: TaxSummarySection;\n\n  @Type(() => TaxSummarySection)\n  sole: TaxSummarySection;\n\n  @Type(() => TaxSummarySection)\n  summary: TaxSummarySection;\n\n  projectedTaxPosition: number;\n\n  get sections(): TaxSummarySection[] {\n    return [this.work, this.property, this.other, this.sole, this.summary];\n  }\n\n  get taxPercent(): number {\n    // Check if netAmount is not 0 to avoid division by zero\n    if (!this.summary.netAmount) {\n      return 0;\n    }\n\n    return this.summary.items.findByCategory(TaxReturnCategoryListEnum.GROSS_TAX_PAYABLE).amount / this.summary.netAmount;\n  }\n\n  /**\n   * Work Net Cash = Income - tax withheld - expenses - interest\n   * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main\n   */\n  get workNetCash(): number {\n    const taxWithheld: number = this.summary.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.work.taxWithheld, TaxSummarySectionEnum.WORK_TANK);\n\n    return this.workNetTotal - Math.abs(taxWithheld);\n  }\n\n  /**\n   * Work Net Total = Income - expenses - interest\n   * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main\n   */\n  get workNetTotal(): number {\n    const income: number = this.work.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.work.income, TaxSummarySectionEnum.WORK_TANK);\n    const expenses: number = this.work.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.work.expenses, TaxSummarySectionEnum.WORK_TANK);\n    const interest: number = this.summary.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.work.interest, TaxSummarySectionEnum.WORK_TANK);\n\n    return income - Math.abs(expenses) - Math.abs(interest);\n  }\n\n  /**\n   * Property Net Cash (Cash Position) = Rental Income - expenses - interest\n   * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main\n   */\n  get propertyNetCash(): number {\n    const income: number = this.property.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.property.income, TaxSummarySectionEnum.PROPERTY_TANK);\n    const expenses: number = this.property.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.property.expenses, TaxSummarySectionEnum.PROPERTY_TANK);\n    const interest: number = this.property.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.property.interest, TaxSummarySectionEnum.PROPERTY_TANK);\n\n    return income - Math.abs(expenses) - Math.abs(interest);\n  }\n\n  /**\n   * Property Net Total (Tax Position) = Rental Income - expenses - interest - depreciation\n   * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main\n   */\n  get propertyNetTotal(): number {\n    const depreciation: number = this.property.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.property.depreciation, TaxSummarySectionEnum.PROPERTY_TANK);\n\n    return this.propertyNetCash - Math.abs(depreciation);\n  }\n\n  /**\n   * Other Net Cash = gross income – expenses – tax withheld - tax instalments\n   * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main\n   */\n  get otherNetCash(): number {\n    const income: number = this.other.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.other.income, TaxSummarySectionEnum.OTHER_TANK);\n    const expenses: number = this.other.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.other.expenses, TaxSummarySectionEnum.OTHER_TANK);\n    const taxWithheld: number = this.summary.items.sumByCategoriesAndSection([TaxReturnCategoryListEnum.TAX_WITHHELD], TaxSummarySectionEnum.OTHER_TANK);\n    const taxInstalments: number = this.summary.items.sumByCategoriesAndSection([TaxReturnCategoryListEnum.TAX_INSTALMENTS], TaxSummarySectionEnum.OTHER_TANK);\n\n    return income - Math.abs(expenses) - Math.abs(taxWithheld) - Math.abs(taxInstalments);\n  }\n\n  /**\n   * Other Net Total = Gross income - expenses + tax offsets + tax instalments + franking credits\n   * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main\n   */\n  get otherNetTotal(): number {\n    const income: number = this.other.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.other.income, TaxSummarySectionEnum.OTHER_TANK);\n    const expenses: number = this.other.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.other.expenses, TaxSummarySectionEnum.OTHER_TANK);\n    const taxOffsets: number = this.summary.items.sumByCategoriesAndSection([TaxReturnCategoryListEnum.TAX_OFFSETS], TaxSummarySectionEnum.SUMMARY);\n    const taxInstallments: number = this.summary.items.sumByCategoriesAndSection([TaxReturnCategoryListEnum.TAX_INSTALMENTS], TaxSummarySectionEnum.OTHER_TANK);\n    const frankingCredits: number = this.summary.items.sumByCategoriesAndSection([TaxReturnCategoryListEnum.FRANKING_CREDITS], TaxSummarySectionEnum.OTHER_TANK);\n\n    return income - Math.abs(expenses) + Math.abs(taxOffsets) + Math.abs(taxInstallments) + Math.abs(frankingCredits);\n  }\n\n  /**\n   * Sole Net Cash = gross income – expenses\n   * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main\n   */\n  get soleNetCash(): number {\n    const income: number = this.sole.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.sole.income, TaxSummarySectionEnum.SOLE_TANK);\n    const expenses: number = this.sole.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.sole.expenses, TaxSummarySectionEnum.SOLE_TANK);\n\n    return income + expenses;\n  }\n\n  /**\n   * Sole Net Total = Gross income - expenses\n   * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main\n   */\n  get soleNetTotal(): number {\n    const income: number = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.income);\n    const expenses: number = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.expenses);\n    const depreciation: number = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.depreciation);\n    const loss: number = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.loss);\n    const lossCurrent: number = this.sole.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.sole.lossCurrent, TaxSummarySectionEnum.SOLE_TANK);\n\n    return income + expenses + depreciation + loss + lossCurrent;\n  }\n}\n"]}
|