taxtank-core 0.28.42 → 0.28.43
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 +68 -15
- package/bundles/taxtank-core.umd.js.map +1 -1
- package/esm2015/lib/collections/tax-summary/report-item.collection.js +34 -4
- package/esm2015/lib/collections/tax-summary/tax-return-categories.const.js +7 -2
- package/esm2015/lib/db/Enums/tax-return-category-list.enum.js +4 -1
- package/esm2015/lib/models/tax-summary/tax-summary.js +7 -5
- package/esm2015/lib/services/http/sole/sole-invoice/sole-invoice.service.js +3 -3
- package/fesm2015/taxtank-core.js +50 -9
- package/fesm2015/taxtank-core.js.map +1 -1
- package/lib/collections/tax-summary/report-item.collection.d.ts +12 -1
- package/lib/db/Enums/tax-return-category-list.enum.d.ts +4 -1
- package/package.json +1 -1
|
@@ -20,6 +20,18 @@ export class ReportItemCollection extends Collection {
|
|
|
20
20
|
}
|
|
21
21
|
return this.create(result);
|
|
22
22
|
}
|
|
23
|
+
getByCategory(categoryId) {
|
|
24
|
+
let result = [];
|
|
25
|
+
for (let reportItem of this.items) {
|
|
26
|
+
if (reportItem.taxReturnCategory.id === categoryId) {
|
|
27
|
+
result.push(reportItem);
|
|
28
|
+
}
|
|
29
|
+
else if (reportItem.items && reportItem.items.getByCategory(categoryId).length) {
|
|
30
|
+
result.push(...reportItem.items.getByCategory(categoryId));
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
return result;
|
|
34
|
+
}
|
|
23
35
|
/**
|
|
24
36
|
* Recursively find report item by Tax Return Category ID
|
|
25
37
|
*/
|
|
@@ -39,17 +51,35 @@ export class ReportItemCollection extends Collection {
|
|
|
39
51
|
return result;
|
|
40
52
|
}
|
|
41
53
|
/**
|
|
42
|
-
*
|
|
54
|
+
* get Collection of report items by Tax Return Categories IDs (one item per category)
|
|
43
55
|
*/
|
|
44
|
-
|
|
56
|
+
findByCategories(categories) {
|
|
45
57
|
return this.create(compact(categories.map((category) => this.findByCategory(category))));
|
|
46
58
|
}
|
|
59
|
+
/**
|
|
60
|
+
* Get Collection of report items by Tax Return Categories IDs (all items per category)
|
|
61
|
+
*/
|
|
62
|
+
getByCategories(categories) {
|
|
63
|
+
const reportItems = [];
|
|
64
|
+
categories.forEach((category) => {
|
|
65
|
+
reportItems.push(...this.getByCategory(category));
|
|
66
|
+
});
|
|
67
|
+
return this.create(reportItems);
|
|
68
|
+
}
|
|
47
69
|
/**
|
|
48
70
|
* A short call to a chain of methods that we often use.
|
|
49
71
|
* Get total amount of report items by Tax Return categories and Tax Summary Section.
|
|
50
72
|
*/
|
|
51
73
|
sumByCategoriesAndSection(categories, section) {
|
|
52
|
-
return this.
|
|
74
|
+
return this.findByCategories(categories).getBySection(section).sumBy('amount');
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* @TODO vik refactor once Nicole approved
|
|
78
|
+
* unlike sumByCategoriesAndSection, which find just one reportItem per category,
|
|
79
|
+
* this method will search for recursively for all matches
|
|
80
|
+
*/
|
|
81
|
+
sumByCategories(categories) {
|
|
82
|
+
return this.getByCategories(categories).sumBy('amount');
|
|
53
83
|
}
|
|
54
84
|
/**
|
|
55
85
|
* Get collection of all report item details related to passed income source
|
|
@@ -68,4 +98,4 @@ export class ReportItemCollection extends Collection {
|
|
|
68
98
|
return new Collection(result);
|
|
69
99
|
}
|
|
70
100
|
}
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"report-item.collection.js","sourceRoot":"","sources":["../../../../../../projects/tt-core/src/lib/collections/tax-summary/report-item.collection.ts"],"names":[],"mappings":"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","sourcesContent":["import {Collection} from '../collection';\nimport {ReportItem} from '../../models/tax-summary/report-item';\nimport {TaxReturnCategoryListEnum} from '../../db/Enums/tax-return-category-list.enum';\nimport {ReportItemDetails} from '../../models/tax-summary/report-item-details';\nimport {TaxSummarySectionEnum} from '../../db/Enums/tax-summary-section.enum';\nimport {IncomeSource} from '../../models/income-source/income-source';\nimport compact from 'lodash/compact';\nimport {TAX_RETURN_CATEGORIES} from './tax-return-categories.const';\n\n/**\n * collection for tax return category items\n */\nexport class ReportItemCollection extends Collection<ReportItem> {\n  /**\n   * Recursively get collection of report items by Tax Summary Section.\n   * Search items which has details\n   */\n  getBySection(section: TaxSummarySectionEnum): ReportItemCollection {\n    let result: ReportItem[] = [];\n\n    for (let reportItem of this.items) {\n      if ((reportItem.details.length || reportItem.amount) && reportItem.taxReturnCategory.section === section) {\n        result.push(reportItem)\n      } else {\n        result.push(...reportItem.items.getBySection(section).toArray());\n      }\n    }\n\n    return this.create(result);\n  }\n\n  getByCategory(categoryId: TaxReturnCategoryListEnum): ReportItem[] {\n    let result: ReportItem[] = [];\n\n    for (let reportItem of this.items) {\n      if (reportItem.taxReturnCategory.id === categoryId) {\n        result.push(reportItem);\n      } else if(reportItem.items && reportItem.items.getByCategory(categoryId).length) {\n        result.push(...reportItem.items.getByCategory(categoryId));\n      }\n    }\n\n    return result;\n  }\n\n  /**\n   * Recursively find report item by Tax Return Category ID\n   */\n  findByCategory(categoryId: TaxReturnCategoryListEnum): ReportItem {\n    let result: ReportItem;\n\n    for (let reportItem of this.items) {\n      if (result) {\n        break;\n      }\n\n      if (reportItem.taxReturnCategory.id === categoryId) {\n        result = reportItem;\n      } else {\n        result = reportItem.items.findByCategory(categoryId);\n      }\n    }\n\n    return result;\n  }\n\n  /**\n   * get Collection of report items by Tax Return Categories IDs (one item per category)\n   */\n  findByCategories(categories: TaxReturnCategoryListEnum[]): ReportItemCollection {\n    return this.create(\n      compact(categories.map((category: TaxReturnCategoryListEnum) => this.findByCategory(category)))\n    );\n  }\n\n  /**\n   * Get Collection of report items by Tax Return Categories IDs (all items per category)\n   */\n  getByCategories(categories: TaxReturnCategoryListEnum[]): ReportItemCollection {\n    const reportItems: ReportItem[] = [];\n    categories.forEach((category) => {\n      reportItems.push(...this.getByCategory(category));\n    });\n\n    return this.create(reportItems);\n  }\n\n  /**\n   * A short call to a chain of methods that we often use.\n   * Get total amount of report items by Tax Return categories and Tax Summary Section.\n   */\n  sumByCategoriesAndSection(categories: TaxReturnCategoryListEnum[], section: TaxSummarySectionEnum): number {\n    return this.findByCategories(categories).getBySection(section).sumBy('amount');\n  }\n\n  /**\n   * @TODO vik refactor once Nicole approved\n   * unlike sumByCategoriesAndSection, which find just one reportItem per category,\n   * this method will search for recursively for all matches\n   */\n  sumByCategories(categories: TaxReturnCategoryListEnum[]): number {\n    return this.getByCategories(categories).sumBy('amount');\n  }\n\n  /**\n   * Get collection of all report item details related to passed income source\n   * @TODO Alex: consider to create and move to ReportItemDetailsCollection\n   */\n  getDetailsByIncomeSource(incomeSource: IncomeSource): Collection<ReportItemDetails> {\n    let result: ReportItemDetails[] = [];\n\n    for (let reportItem of this.items) {\n      if (reportItem.details.length) {\n        result.push(...reportItem.details.filter((details: ReportItemDetails) => details.name === incomeSource.name));\n      } else {\n        result.push(...reportItem.items.getDetailsByIncomeSource(incomeSource).toArray());\n      }\n    }\n\n    return new Collection<ReportItemDetails>(result);\n  }\n}\n"]}
|
|
@@ -82,13 +82,18 @@ export const TAX_RETURN_CATEGORIES = {
|
|
|
82
82
|
TaxReturnCategoryListEnum.RENT_EXPENSES,
|
|
83
83
|
TaxReturnCategoryListEnum.INTEREST_EXPENSES_WITHIN_AUSTRALIA,
|
|
84
84
|
TaxReturnCategoryListEnum.INTEREST_EXPENSES_OVERSEAS,
|
|
85
|
-
TaxReturnCategoryListEnum.DEPRECIATION_EXPENSES,
|
|
86
85
|
TaxReturnCategoryListEnum.MOTOR_VEHICLE_EXPENSES,
|
|
87
86
|
TaxReturnCategoryListEnum.ALL_OTHER_EXPENSES
|
|
88
87
|
],
|
|
88
|
+
depreciation: [
|
|
89
|
+
TaxReturnCategoryListEnum.DEPRECIATION_EXPENSES,
|
|
90
|
+
],
|
|
91
|
+
loss: [
|
|
92
|
+
TaxReturnCategoryListEnum.DEFERRED_BUSINESS_LOSSES_FROM_PRIOR_YEAR,
|
|
93
|
+
],
|
|
89
94
|
taxOffsets: [
|
|
90
95
|
TaxReturnCategoryListEnum.TAX_OFFSETS_SOLE
|
|
91
96
|
],
|
|
92
97
|
},
|
|
93
98
|
};
|
|
94
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGF4LXJldHVybi1jYXRlZ29yaWVzLmNvbnN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHQtY29yZS9zcmMvbGliL2NvbGxlY3Rpb25zL3RheC1zdW1tYXJ5L3RheC1yZXR1cm4tY2F0ZWdvcmllcy5jb25zdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSw4Q0FBOEMsQ0FBQztBQUV2RixNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBa0U7SUFDbEcsSUFBSSxFQUFFO1FBQ0osTUFBTSxFQUFFO1lBQ04seUJBQXlCLENBQUMsTUFBTTtZQUNoQyx5QkFBeUIsQ0FBQyxzQ0FBc0M7WUFDaEUseUJBQXlCLENBQUMsMEJBQTBCO1lBQ3BELHlCQUF5QixDQUFDLEdBQUc7WUFDN0IseUJBQXlCLENBQUMscUJBQXFCO1lBQy9DLHlCQUF5QixDQUFDLG1CQUFtQjtZQUM3Qyx5QkFBeUIsQ0FBQyw4QkFBOEI7WUFDeEQseUJBQXlCLENBQUMsZ0NBQWdDO1lBQzFELHlCQUF5QixDQUFDLHFCQUFxQjtTQUNoRDtRQUNELFFBQVEsRUFBRTtZQUNSLHlCQUF5QixDQUFDLGFBQWE7U0FDeEM7UUFDRCxRQUFRLEVBQUU7WUFDUix5QkFBeUIsQ0FBQyxjQUFjO1NBQ3pDO1FBQ0QsV0FBVyxFQUFFO1lBQ1gseUJBQXlCLENBQUMsWUFBWTtTQUN2QztLQUNGO0lBQ0QsUUFBUSxFQUFFO1FBQ1IsTUFBTSxFQUFFO1lBQ04seUJBQXlCLENBQUMsVUFBVTtTQUNyQztRQUNELFFBQVEsRUFBRTtZQUNSLHlCQUF5QixDQUFDLHVCQUF1QjtTQUNsRDtRQUNELFFBQVEsRUFBRTtZQUNSLHlCQUF5QixDQUFDLG1CQUFtQjtTQUM5QztRQUNELFlBQVksRUFBRTtZQUNaLHlCQUF5QixDQUFDLGFBQWE7WUFDdkMscUZBQXFGO1lBQ3JGLHlCQUF5QixDQUFDLG1CQUFtQjtTQUM5QztLQUNGO0lBQ0QsS0FBSyxFQUFFO1FBQ0wsTUFBTSxFQUFFO1lBQ04seUJBQXlCLENBQUMsY0FBYztZQUN4Qyx5QkFBeUIsQ0FBQyxTQUFTO1lBQ25DLHlCQUF5QixDQUFDLGFBQWE7WUFDdkMseUJBQXlCLENBQUMsWUFBWTtZQUN0Qyx5QkFBeUIsQ0FBQyxNQUFNO1lBQ2hDLHlCQUF5QixDQUFDLGNBQWM7WUFDeEMseUJBQXlCLENBQUMsMkJBQTJCO1lBQ3JELHlCQUF5QixDQUFDLGFBQWE7WUFDdkMseUJBQXlCLENBQUMscUJBQXFCO1lBQy9DLHlCQUF5QixDQUFDLDJCQUEyQjtZQUNyRCx5QkFBeUIsQ0FBQyxtQ0FBbUM7WUFDN0QseUJBQXlCLENBQUMsWUFBWTtTQUN2QztRQUNELFFBQVEsRUFBRTtZQUNSLHlCQUF5QixDQUFDLGdCQUFnQjtTQUMzQztRQUNELFVBQVUsRUFBRTtZQUNWLHlCQUF5QixDQUFDLFdBQVc7U0FDdEM7UUFDRCxVQUFVLEVBQUU7WUFDVix5QkFBeUIsQ0FBQyxXQUFXO1lBQ3JDLHlCQUF5QixDQUFDLGVBQWU7WUFDekMseUJBQXlCLENBQUMsa0JBQWtCO1NBQzdDO0tBQ0Y7SUFDRCxJQUFJLEVBQUU7UUFDSixNQUFNLEVBQUU7WUFDTix5QkFBeUIsQ0FBQywyQkFBMkI7WUFDckQseUJBQXlCLENBQUMsa0NBQWtDO1lBQzVELHlCQUF5QixDQUFDLG1DQUFtQztZQUM3RCx5QkFBeUIsQ0FBQyw4QkFBOEI7WUFDeEQseUJBQXlCLENBQUMscUJBQXFCO1NBQ2hEO1FBQ0QsUUFBUSxFQUFFO1lBQ1IseUJBQXlCLENBQUMseUJBQXlCO1lBQ25ELHlCQUF5QixDQUFDLDhDQUE4QztZQUN4RSx5QkFBeUIsQ0FBQyx1QkFBdUI7WUFDakQseUJBQXlCLENBQUMsU0FBUztZQUNuQyx5QkFBeUIsQ0FBQyxjQUFjO1lBQ3hDLHlCQUF5QixDQUFDLGFBQWE7WUFDdkMseUJBQXlCLENBQUMsa0NBQWtDO1lBQzVELHlCQUF5QixDQUFDLDBCQUEwQjtZQUNwRCx5QkFBeUIsQ0FBQyxzQkFBc0I7WUFDaEQseUJBQXlCLENBQUMsa0JBQWtCO1NBQzdDO1FBQ0QsWUFBWSxFQUFFO1lBQ1oseUJBQXlCLENBQUMscUJBQXFCO1NBQ2hEO1FBQ0QsSUFBSSxFQUFFO1lBQ0oseUJBQXlCLENBQUMsd0NBQXdDO1NBQ25FO1FBQ0QsVUFBVSxFQUFFO1lBQ1YseUJBQXlCLENBQUMsZ0JBQWdCO1NBQzNDO0tBQ0Y7Q0FDRixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtfSBmcm9tICcuLi8uLi9kYi9FbnVtcy90YXgtcmV0dXJuLWNhdGVnb3J5LWxpc3QuZW51bSc7XG5cbmV4cG9ydCBjb25zdCBUQVhfUkVUVVJOX0NBVEVHT1JJRVM6IHtba2V5OiBzdHJpbmddOiB7W2tleTogc3RyaW5nXTogVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bVtdfX0gPSB7XG4gIHdvcms6IHtcbiAgICBpbmNvbWU6IFtcbiAgICAgIFRheFJldHVybkNhdGVnb3J5TGlzdEVudW0uU0FMQVJZLFxuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5BTExPV0FOQ0VTX0VBUk5JTkdTX1RJUFNfRElSRUNUT1JfRkVFUyxcbiAgICAgIFRheFJldHVybkNhdGVnb3J5TGlzdEVudW0uRU1QTE9ZRVJfTFVNUF9TVU1fUEFZTUVOVFMsXG4gICAgICBUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtLkVUUCxcbiAgICAgIFRheFJldHVybkNhdGVnb3J5TGlzdEVudW0uR09WRVJOTUVOVF9BTExPV0FOQ0VTLFxuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5HT1ZFUk5NRU5UX1BFTlNJT05TLFxuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5BTk5VSVRJRVNfU1VQRVJfSU5DT01FX1NUUkVBTVMsXG4gICAgICBUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtLlNVUEVSQU5OVUFUSU9OX0xVTVBfU1VNX1BBWU1FTlRTLFxuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5BVFRSSUJVVEVEX1BTSV9JTkNPTUVcbiAgICBdLFxuICAgIGV4cGVuc2VzOiBbXG4gICAgICBUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtLldPUktfRVhQRU5TRVNcbiAgICBdLFxuICAgIGludGVyZXN0OiBbXG4gICAgICBUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtLkdST1NTX0lOVEVSRVNUXG4gICAgXSxcbiAgICB0YXhXaXRoaGVsZDogW1xuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5UQVhfV0lUSEhFTERcbiAgICBdXG4gIH0sXG4gIHByb3BlcnR5OiB7XG4gICAgaW5jb21lOiBbXG4gICAgICBUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtLkdST1NTX1JFTlRcbiAgICBdLFxuICAgIGV4cGVuc2VzOiBbXG4gICAgICBUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtLk9USEVSX1JFTlRBTF9ERURVQ1RJT05TXG4gICAgXSxcbiAgICBpbnRlcmVzdDogW1xuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5JTlRFUkVTVF9ERURVQ1RJT05TXG4gICAgXSxcbiAgICBkZXByZWNpYXRpb246IFtcbiAgICAgIFRheFJldHVybkNhdGVnb3J5TGlzdEVudW0uQ0FQSVRBTF9XT1JLUyxcbiAgICAgIC8vIEBUT0RPIE5pay9BbGV4IChpdCB3YXMgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5ERVBSRUNJQVRJT04gd2hpY2ggZG9lc24ndCBleGlzdClcbiAgICAgIFRheFJldHVybkNhdGVnb3J5TGlzdEVudW0uUExBTlRfQU5EX0VRVUlQTUVOVFxuICAgIF1cbiAgfSxcbiAgb3RoZXI6IHtcbiAgICBpbmNvbWU6IFtcbiAgICAgIFRheFJldHVybkNhdGVnb3J5TGlzdEVudW0uR1JPU1NfSU5URVJFU1QsXG4gICAgICBUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtLkRJVklERU5EUyxcbiAgICAgIFRheFJldHVybkNhdGVnb3J5TGlzdEVudW0uU0hBUkVfU0NIRU1FUyxcbiAgICAgIFRheFJldHVybkNhdGVnb3J5TGlzdEVudW0uUEFSVE5FUlNISVBTLFxuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5UUlVTVFMsXG4gICAgICBUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtLlBTSV9TQkVfSU5DT01FLFxuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5TT0xFX1RSQURFUl9CVVNJTkVTU19JTkNPTUUsXG4gICAgICBUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtLkNBUElUQUxfR0FJTlMsXG4gICAgICBUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtLkZPUkVJR05fU09VUkNFX0lOQ09NRSxcbiAgICAgIFRheFJldHVybkNhdGVnb3J5TGlzdEVudW0uQk9OVVNFU19GUk9NX0xJRkVfSU5TVVJBTkNFLFxuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5GT1JFU1RSWV9NQU5BR0VEX0lOVkVTVE1FTlRfU0NIRU1FUyxcbiAgICAgIFRheFJldHVybkNhdGVnb3J5TGlzdEVudW0uT1RIRVJfSU5DT01FXG4gICAgXSxcbiAgICBleHBlbnNlczogW1xuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5PVEhFUl9ERURVQ1RJT05TXG4gICAgXSxcbiAgICB0YXhDcmVkaXRzOiBbXG4gICAgICBUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtLlRBWF9DUkVESVRTXG4gICAgXSxcbiAgICB0YXhPZmZzZXRzOiBbXG4gICAgICBUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtLlRBWF9PRkZTRVRTLFxuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5UQVhfT0ZGU0VUU19MT1csXG4gICAgICBUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtLlRBWF9PRkZTRVRTX01JRERMRSxcbiAgICBdXG4gIH0sXG4gIHNvbGU6IHtcbiAgICBpbmNvbWU6IFtcbiAgICAgIFRheFJldHVybkNhdGVnb3J5TGlzdEVudW0uR1JPU1NfUEFZTUVOVFNfTk9fQUJOX0dJVkVOLFxuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5HUk9TU19QQVlNRU5UU19WT0xVTlRBUllfQUdSRUVNRU5ULFxuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5HUk9TU19QQVlNRU5UU19MQUJPVVJfSElSRV9PUl9PVEhFUixcbiAgICAgIFRheFJldHVybkNhdGVnb3J5TGlzdEVudW0uQVNTRVNTQUJMRV9HT1ZFUk5NRU5UX1BBWU1FTlRTLFxuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5PVEhFUl9CVVNJTkVTU19JTkNPTUVcbiAgICBdLFxuICAgIGV4cGVuc2VzOiBbXG4gICAgICBUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtLlBVUkNIQVNFU19BTkRfT1RIRVJfQ09TVFMsXG4gICAgICBUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtLkNPTlRSQUNUT1JTX1NVQkNPTlRSQUNUT1JTX0NPTU1JU1NJT05fRVhQRU5TRVMsXG4gICAgICBUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtLlNVUEVSQU5OVUFUSU9OX0VYUEVOU0VTLFxuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5CQURfREVCVFMsXG4gICAgICBUYXhSZXR1cm5DYXRlZ29yeUxpc3RFbnVtLkxFQVNFX0VYUEVOU0VTLFxuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5SRU5UX0VYUEVOU0VTLFxuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5JTlRFUkVTVF9FWFBFTlNFU19XSVRISU5fQVVTVFJBTElBLFxuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5JTlRFUkVTVF9FWFBFTlNFU19PVkVSU0VBUyxcbiAgICAgIFRheFJldHVybkNhdGVnb3J5TGlzdEVudW0uTU9UT1JfVkVISUNMRV9FWFBFTlNFUyxcbiAgICAgIFRheFJldHVybkNhdGVnb3J5TGlzdEVudW0uQUxMX09USEVSX0VYUEVOU0VTXG4gICAgXSxcbiAgICBkZXByZWNpYXRpb246IFtcbiAgICAgIFRheFJldHVybkNhdGVnb3J5TGlzdEVudW0uREVQUkVDSUFUSU9OX0VYUEVOU0VTLFxuICAgIF0sXG4gICAgbG9zczogW1xuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5ERUZFUlJFRF9CVVNJTkVTU19MT1NTRVNfRlJPTV9QUklPUl9ZRUFSLFxuICAgIF0sXG4gICAgdGF4T2Zmc2V0czogW1xuICAgICAgVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bS5UQVhfT0ZGU0VUU19TT0xFXG4gICAgXSxcbiAgfSxcbn1cbiJdfQ==
|
|
@@ -59,5 +59,8 @@ export var TaxReturnCategoryListEnum;
|
|
|
59
59
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["TAX_OFFSETS_MIDDLE"] = 62] = "TAX_OFFSETS_MIDDLE";
|
|
60
60
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["TAX_OFFSETS_SOLE"] = 63] = "TAX_OFFSETS_SOLE";
|
|
61
61
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["TAX_PAYABLE"] = 28] = "TAX_PAYABLE";
|
|
62
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["BUSINESS_INCOME_OR_LOSS"] = 59] = "BUSINESS_INCOME_OR_LOSS";
|
|
63
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["DEFERRED_BUSINESS_LOSSES_FROM_PRIOR_YEAR"] = 64] = "DEFERRED_BUSINESS_LOSSES_FROM_PRIOR_YEAR";
|
|
64
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["DEFERRED_BUSINESS_LOSSES"] = 60] = "DEFERRED_BUSINESS_LOSSES";
|
|
62
65
|
})(TaxReturnCategoryListEnum || (TaxReturnCategoryListEnum = {}));
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGF4LXJldHVybi1jYXRlZ29yeS1saXN0LmVudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dC1jb3JlL3NyYy9saWIvZGIvRW51bXMvdGF4LXJldHVybi1jYXRlZ29yeS1saXN0LmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVkseUJBK0RYO0FBL0RELFdBQVkseUJBQXlCO0lBQ25DLDZFQUFVLENBQUE7SUFDViw4SUFBMkMsQ0FBQTtJQUMzQyxzSEFBK0IsQ0FBQTtJQUMvQix3RUFBUSxDQUFBO0lBQ1IsMkdBQXlCLENBQUE7SUFDekIsd0dBQXdCLENBQUE7SUFDeEIsNkhBQWtDLENBQUE7SUFDbEMsa0lBQXFDLENBQUE7SUFDckMsMkdBQXlCLENBQUE7SUFDekIsNkZBQWtCLENBQUE7SUFDbEIsbUZBQWEsQ0FBQTtJQUNiLDRGQUFrQixDQUFBO0lBQ2xCLHFGQUFjLENBQUE7SUFDZCx3R0FBd0IsQ0FBQTtJQUN4QiwwRkFBaUIsQ0FBQTtJQUNqQiw4RUFBVyxDQUFBO0lBQ1gsOEZBQW1CLENBQUE7SUFDbkIsd0hBQWdDLENBQUE7SUFDaEMsNEZBQWtCLENBQUE7SUFDbEIsNEdBQTBCLENBQUE7SUFDMUIsd0hBQWdDLENBQUE7SUFDaEMsd0lBQXdDLENBQUE7SUFDeEMsMEZBQWlCLENBQUE7SUFDakIsd0hBQWdDLENBQUE7SUFDaEMsc0lBQXVDLENBQUE7SUFDdkMsd0lBQXdDLENBQUE7SUFDeEMsOEhBQW1DLENBQUE7SUFDbkMsNEdBQTBCLENBQUE7SUFDMUIsMkZBQWlCLENBQUE7SUFDakIsdUdBQXVCLENBQUE7SUFDdkIsNEZBQWtCLENBQUE7SUFDbEIsd0dBQXdCLENBQUE7SUFDeEIsc0dBQXVCLENBQUE7SUFDdkIsZ0hBQTRCLENBQUE7SUFDNUIsa0dBQXFCLENBQUE7SUFDckIsb0hBQThCLENBQUE7SUFDOUIsOEpBQW1ELENBQUE7SUFDbkQsZ0hBQTRCLENBQUE7SUFDNUIsb0ZBQWMsQ0FBQTtJQUNkLDhGQUFtQixDQUFBO0lBQ25CLDRGQUFrQixDQUFBO0lBQ2xCLHNJQUF1QyxDQUFBO0lBQ3ZDLHNIQUErQixDQUFBO0lBQy9CLDRHQUEwQixDQUFBO0lBQzFCLDhHQUEyQixDQUFBO0lBQzNCLHNHQUF1QixDQUFBO0lBQ3ZCLG9HQUFzQixDQUFBO0lBQ3RCLDRHQUEwQixDQUFBO0lBQzFCLGtGQUFhLENBQUE7SUFDYiw4R0FBMkIsQ0FBQTtJQUMzQix3RkFBZ0IsQ0FBQTtJQUNoQiwwRkFBaUIsQ0FBQTtJQUNqQixnR0FBb0IsQ0FBQTtJQUNwQixrR0FBcUIsQ0FBQTtJQUNyQix3RkFBZ0IsQ0FBQTtJQUNoQixnR0FBb0IsQ0FBQTtJQUNwQixzR0FBdUIsQ0FBQTtJQUN2QixrR0FBcUIsQ0FBQTtJQUNyQix3RkFBZ0IsQ0FBQTtJQUNoQixnSEFBNEIsQ0FBQTtJQUM1QixrSkFBNkMsQ0FBQTtJQUM3QyxrSEFBNkIsQ0FBQTtBQUMvQixDQUFDLEVBL0RXLHlCQUF5QixLQUF6Qix5QkFBeUIsUUErRHBDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gVGF4UmV0dXJuQ2F0ZWdvcnlMaXN0RW51bSB7XG4gIFNBTEFSWSA9IDEsXG4gIEFMTE9XQU5DRVNfRUFSTklOR1NfVElQU19ESVJFQ1RPUl9GRUVTID0gMzAsXG4gIEVNUExPWUVSX0xVTVBfU1VNX1BBWU1FTlRTID0gMzEsXG4gIEVUUCA9IDMyLFxuICBHT1ZFUk5NRU5UX0FMTE9XQU5DRVMgPSAyLFxuICBHT1ZFUk5NRU5UX1BFTlNJT05TID0gMzMsXG4gIEFOTlVJVElFU19TVVBFUl9JTkNPTUVfU1RSRUFNUyA9IDMsXG4gIFNVUEVSQU5OVUFUSU9OX0xVTVBfU1VNX1BBWU1FTlRTID0gMzQsXG4gIEFUVFJJQlVURURfUFNJX0lOQ09NRSA9IDQsXG4gIEdST1NTX0lOVEVSRVNUID0gNSxcbiAgRElWSURFTkRTID0gNixcbiAgU0hBUkVfU0NIRU1FUyA9IDM1LFxuICBHUk9TU19SRU5UID0gOCxcbiAgUEFSVE5FUlNISVBTX1RSVVNUUyA9IDEzLFxuICBQQVJUTkVSU0hJUFMgPSAzNixcbiAgVFJVU1RTID0gMzcsXG4gIFBTSV9TQkVfSU5DT01FID0gMTQsXG4gIFNPTEVfVFJBREVSX0JVU0lORVNTX0lOQ09NRSA9IDM4LFxuICBDQVBJVEFMX0dBSU5TID0gMTUsXG4gIEZPUkVJR05fU09VUkNFX0lOQ09NRSA9IDE2LFxuICBCT05VU0VTX0ZST01fTElGRV9JTlNVUkFOQ0UgPSAxNyxcbiAgRk9SRVNUUllfTUFOQUdFRF9JTlZFU1RNRU5UX1NDSEVNRVMgPSAzOSxcbiAgT1RIRVJfSU5DT01FID0gNDAsXG4gIEdST1NTX1BBWU1FTlRTX05PX0FCTl9HSVZFTiA9IDQyLFxuICBHUk9TU19QQVlNRU5UU19WT0xVTlRBUllfQUdSRUVNRU5UID0gNDMsXG4gIEdST1NTX1BBWU1FTlRTX0xBQk9VUl9ISVJFX09SX09USEVSID0gNDQsXG4gIEFTU0VTU0FCTEVfR09WRVJOTUVOVF9QQVlNRU5UUyA9IDQ1LFxuICBPVEhFUl9CVVNJTkVTU19JTkNPTUUgPSA0NixcbiAgV09SS19FWFBFTlNFUyA9IDcsXG4gIElOVEVSRVNUX0RFRFVDVElPTlMgPSA5LFxuICBDQVBJVEFMX1dPUktTID0gMTAsXG4gIFBMQU5UX0FORF9FUVVJUE1FTlQgPSAxMSxcbiAgQk9SUk9XSU5HX0VYUEVOU0VTID0gMjksXG4gIE9USEVSX1JFTlRBTF9ERURVQ1RJT05TID0gMTIsXG4gIE9USEVSX0RFRFVDVElPTlMgPSAxOCxcbiAgUFVSQ0hBU0VTX0FORF9PVEhFUl9DT1NUUyA9IDQ4LFxuICBDT05UUkFDVE9SU19TVUJDT05UUkFDVE9SU19DT01NSVNTSU9OX0VYUEVOU0VTID0gNDksXG4gIFNVUEVSQU5OVUFUSU9OX0VYUEVOU0VTID0gNTAsXG4gIEJBRF9ERUJUUyA9IDUxLFxuICBMRUFTRV9FWFBFTlNFUyA9IDUyLFxuICBSRU5UX0VYUEVOU0VTID0gNTMsXG4gIElOVEVSRVNUX0VYUEVOU0VTX1dJVEhJTl9BVVNUUkFMSUEgPSA1NCxcbiAgSU5URVJFU1RfRVhQRU5TRVNfT1ZFUlNFQVMgPSA1NSxcbiAgREVQUkVDSUFUSU9OX0VYUEVOU0VTID0gNTYsXG4gIE1PVE9SX1ZFSElDTEVfRVhQRU5TRVMgPSA1NyxcbiAgQUxMX09USEVSX0VYUEVOU0VTID0gNTgsXG4gIEdST1NTX1RBWF9QQVlBQkxFID0gMTksXG4gIFRBWF9PTl9UQVhBQkxFX0lOQ09NRSA9IDIwLFxuICBNRURJQ0FSRSA9IDIxLFxuICBTVFVERU5UX0xPQU5fUkVQQVlNRU5UID0gMjIsXG4gIFRBWF9DUkVESVRTID0gMjMsXG4gIFRBWF9XSVRISEVMRCA9IDI0LFxuICBUQVhfSU5TVEFMTUVOVFMgPSAyNSxcbiAgRlJBTktJTkdfQ1JFRElUUyA9IDI2LFxuICBUQVhfT0ZGU0VUUyA9IDI3LFxuICBUQVhfT0ZGU0VUU19MT1cgPSA2MSxcbiAgVEFYX09GRlNFVFNfTUlERExFID0gNjIsXG4gIFRBWF9PRkZTRVRTX1NPTEUgPSA2MyxcbiAgVEFYX1BBWUFCTEUgPSAyOCxcbiAgQlVTSU5FU1NfSU5DT01FX09SX0xPU1MgPSA1OSxcbiAgREVGRVJSRURfQlVTSU5FU1NfTE9TU0VTX0ZST01fUFJJT1JfWUVBUiA9IDY0LFxuICBERUZFUlJFRF9CVVNJTkVTU19MT1NTRVMgPSA2MFxufVxuIl19
|
|
@@ -85,16 +85,18 @@ export class TaxSummary {
|
|
|
85
85
|
get soleNetCash() {
|
|
86
86
|
const income = this.sole.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.sole.income, TaxSummarySectionEnum.SOLE_TANK);
|
|
87
87
|
const expenses = this.sole.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.sole.expenses, TaxSummarySectionEnum.SOLE_TANK);
|
|
88
|
-
return income
|
|
88
|
+
return income + expenses;
|
|
89
89
|
}
|
|
90
90
|
/**
|
|
91
91
|
* Sole Net Total = Gross income - expenses
|
|
92
92
|
* https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main
|
|
93
93
|
*/
|
|
94
94
|
get soleNetTotal() {
|
|
95
|
-
const income = this.sole.items.
|
|
96
|
-
const expenses = this.sole.items.
|
|
97
|
-
|
|
95
|
+
const income = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.income);
|
|
96
|
+
const expenses = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.expenses);
|
|
97
|
+
const depreciation = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.expenses);
|
|
98
|
+
const loss = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.loss);
|
|
99
|
+
return income + expenses + depreciation - loss;
|
|
98
100
|
}
|
|
99
101
|
}
|
|
100
102
|
__decorate([
|
|
@@ -112,4 +114,4 @@ __decorate([
|
|
|
112
114
|
__decorate([
|
|
113
115
|
Type(() => TaxSummarySection)
|
|
114
116
|
], TaxSummary.prototype, "summary", void 0);
|
|
115
|
-
//# 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 - Math.abs(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.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 - Math.abs(expenses);\n  }\n}\n"]}
|
|
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":"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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.expenses);\n    const loss: number = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.loss);\n\n    return income + expenses + depreciation - loss;\n  }\n}\n"]}
|
|
@@ -2,7 +2,6 @@ import { Injectable } from '@angular/core';
|
|
|
2
2
|
import { RestService } from '../../rest/rest.service';
|
|
3
3
|
import { SoleInvoice } from '../../../../models';
|
|
4
4
|
import { SoleInvoiceStatusesEnum } from '../../../../db/Enums/sole-invoice-statuses.enum';
|
|
5
|
-
import { plainToClass } from 'class-transformer';
|
|
6
5
|
import merge from 'lodash/merge';
|
|
7
6
|
import * as i0 from "@angular/core";
|
|
8
7
|
export class SoleInvoiceService extends RestService {
|
|
@@ -13,8 +12,9 @@ export class SoleInvoiceService extends RestService {
|
|
|
13
12
|
this.isHydra = true;
|
|
14
13
|
}
|
|
15
14
|
updateStatus(invoice, status) {
|
|
15
|
+
const updatedInvoice = Object.assign({}, invoice, { status });
|
|
16
16
|
// use id only to avoid unexpected changes
|
|
17
|
-
return this.update(
|
|
17
|
+
return this.update(updatedInvoice);
|
|
18
18
|
}
|
|
19
19
|
publish(invoice, document) {
|
|
20
20
|
// use id only to avoid unexpected changes
|
|
@@ -32,4 +32,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
|
|
|
32
32
|
providedIn: 'root'
|
|
33
33
|
}]
|
|
34
34
|
}] });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29sZS1pbnZvaWNlLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dC1jb3JlL3NyYy9saWIvc2VydmljZXMvaHR0cC9zb2xlL3NvbGUtaW52b2ljZS9zb2xlLWludm9pY2Uuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUV0RCxPQUFPLEVBQUUsV0FBVyxFQUFZLE1BQU0sb0JBQW9CLENBQUM7QUFDM0QsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0saURBQWlELENBQUM7QUFHMUYsT0FBTyxLQUFLLE1BQU0sY0FBYyxDQUFDOztBQUtqQyxNQUFNLE9BQU8sa0JBQW1CLFNBQVEsV0FBeUM7SUFIakY7O1FBSUUsZUFBVSxHQUF1QixXQUFXLENBQUM7UUFDN0MsUUFBRyxHQUFXLGVBQWUsQ0FBQztRQUM5QixZQUFPLEdBQVksSUFBSSxDQUFDO0tBZ0J6QjtJQWRDLFlBQVksQ0FBQyxPQUFvQixFQUFFLE1BQStCO1FBQ2hFLE1BQU0sY0FBYyxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxFQUFDLE1BQU0sRUFBQyxDQUFDLENBQUM7UUFDNUQsMENBQTBDO1FBQzFDLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQsT0FBTyxDQUFDLE9BQW9CLEVBQUUsUUFBa0I7UUFDOUMsMENBQTBDO1FBQzFDLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsdUJBQXVCLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQ2hHLENBQUM7SUFFRCxTQUFTLENBQUMsT0FBb0I7UUFDNUIsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxJQUFJLElBQUksQ0FBQyxHQUFHLElBQUksT0FBTyxDQUFDLEVBQUUsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3hGLENBQUM7O2dIQWxCVSxrQkFBa0I7b0hBQWxCLGtCQUFrQixjQUZqQixNQUFNOzRGQUVQLGtCQUFrQjtrQkFIOUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBSZXN0U2VydmljZSB9IGZyb20gJy4uLy4uL3Jlc3QvcmVzdC5zZXJ2aWNlJztcbmltcG9ydCB7IFNvbGVJbnZvaWNlIGFzIFNvbGVJbnZvaWNlQmFzZSB9IGZyb20gJy4uLy4uLy4uLy4uL2RiL01vZGVscy9zb2xlL3NvbGUtaW52b2ljZSc7XG5pbXBvcnQgeyBTb2xlSW52b2ljZSwgRG9jdW1lbnQgfSBmcm9tICcuLi8uLi8uLi8uLi9tb2RlbHMnO1xuaW1wb3J0IHsgU29sZUludm9pY2VTdGF0dXNlc0VudW0gfSBmcm9tICcuLi8uLi8uLi8uLi9kYi9FbnVtcy9zb2xlLWludm9pY2Utc3RhdHVzZXMuZW51bSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBwbGFpblRvQ2xhc3MgfSBmcm9tICdjbGFzcy10cmFuc2Zvcm1lcic7XG5pbXBvcnQgbWVyZ2UgZnJvbSAnbG9kYXNoL21lcmdlJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgU29sZUludm9pY2VTZXJ2aWNlIGV4dGVuZHMgUmVzdFNlcnZpY2U8U29sZUludm9pY2VCYXNlLCBTb2xlSW52b2ljZT4ge1xuICBtb2RlbENsYXNzOiB0eXBlb2YgU29sZUludm9pY2UgPSBTb2xlSW52b2ljZTtcbiAgdXJsOiBzdHJpbmcgPSAnc29sZS1pbnZvaWNlcyc7XG4gIGlzSHlkcmE6IGJvb2xlYW4gPSB0cnVlO1xuXG4gIHVwZGF0ZVN0YXR1cyhpbnZvaWNlOiBTb2xlSW52b2ljZSwgc3RhdHVzOiBTb2xlSW52b2ljZVN0YXR1c2VzRW51bSk6IE9ic2VydmFibGU8U29sZUludm9pY2U+IHtcbiAgICBjb25zdCB1cGRhdGVkSW52b2ljZSA9IE9iamVjdC5hc3NpZ24oe30sIGludm9pY2UsIHtzdGF0dXN9KTtcbiAgICAvLyB1c2UgaWQgb25seSB0byBhdm9pZCB1bmV4cGVjdGVkIGNoYW5nZXNcbiAgICByZXR1cm4gdGhpcy51cGRhdGUodXBkYXRlZEludm9pY2UpO1xuICB9XG5cbiAgcHVibGlzaChpbnZvaWNlOiBTb2xlSW52b2ljZSwgZG9jdW1lbnQ6IERvY3VtZW50KTogT2JzZXJ2YWJsZTxTb2xlSW52b2ljZT4ge1xuICAgIC8vIHVzZSBpZCBvbmx5IHRvIGF2b2lkIHVuZXhwZWN0ZWQgY2hhbmdlc1xuICAgIHJldHVybiB0aGlzLnVwZGF0ZShtZXJnZSh7fSwgaW52b2ljZSwgeyBkb2N1bWVudCwgc3RhdHVzOiBTb2xlSW52b2ljZVN0YXR1c2VzRW51bS5QRU5ESU5HIH0pKTtcbiAgfVxuXG4gIHNlbmRFbWFpbChpbnZvaWNlOiBTb2xlSW52b2ljZSkge1xuICAgIHJldHVybiB0aGlzLmh0dHAucG9zdChgJHt0aGlzLmVudmlyb25tZW50LmFwaVYyfS8ke3RoaXMudXJsfS8ke2ludm9pY2UuaWR9L3NlbmRgLCB7fSk7XG4gIH1cbn1cbiJdfQ==
|
package/fesm2015/taxtank-core.js
CHANGED
|
@@ -6995,6 +6995,18 @@ class ReportItemCollection extends Collection {
|
|
|
6995
6995
|
}
|
|
6996
6996
|
return this.create(result);
|
|
6997
6997
|
}
|
|
6998
|
+
getByCategory(categoryId) {
|
|
6999
|
+
let result = [];
|
|
7000
|
+
for (let reportItem of this.items) {
|
|
7001
|
+
if (reportItem.taxReturnCategory.id === categoryId) {
|
|
7002
|
+
result.push(reportItem);
|
|
7003
|
+
}
|
|
7004
|
+
else if (reportItem.items && reportItem.items.getByCategory(categoryId).length) {
|
|
7005
|
+
result.push(...reportItem.items.getByCategory(categoryId));
|
|
7006
|
+
}
|
|
7007
|
+
}
|
|
7008
|
+
return result;
|
|
7009
|
+
}
|
|
6998
7010
|
/**
|
|
6999
7011
|
* Recursively find report item by Tax Return Category ID
|
|
7000
7012
|
*/
|
|
@@ -7014,17 +7026,35 @@ class ReportItemCollection extends Collection {
|
|
|
7014
7026
|
return result;
|
|
7015
7027
|
}
|
|
7016
7028
|
/**
|
|
7017
|
-
*
|
|
7029
|
+
* get Collection of report items by Tax Return Categories IDs (one item per category)
|
|
7018
7030
|
*/
|
|
7019
|
-
|
|
7031
|
+
findByCategories(categories) {
|
|
7020
7032
|
return this.create(compact(categories.map((category) => this.findByCategory(category))));
|
|
7021
7033
|
}
|
|
7034
|
+
/**
|
|
7035
|
+
* Get Collection of report items by Tax Return Categories IDs (all items per category)
|
|
7036
|
+
*/
|
|
7037
|
+
getByCategories(categories) {
|
|
7038
|
+
const reportItems = [];
|
|
7039
|
+
categories.forEach((category) => {
|
|
7040
|
+
reportItems.push(...this.getByCategory(category));
|
|
7041
|
+
});
|
|
7042
|
+
return this.create(reportItems);
|
|
7043
|
+
}
|
|
7022
7044
|
/**
|
|
7023
7045
|
* A short call to a chain of methods that we often use.
|
|
7024
7046
|
* Get total amount of report items by Tax Return categories and Tax Summary Section.
|
|
7025
7047
|
*/
|
|
7026
7048
|
sumByCategoriesAndSection(categories, section) {
|
|
7027
|
-
return this.
|
|
7049
|
+
return this.findByCategories(categories).getBySection(section).sumBy('amount');
|
|
7050
|
+
}
|
|
7051
|
+
/**
|
|
7052
|
+
* @TODO vik refactor once Nicole approved
|
|
7053
|
+
* unlike sumByCategoriesAndSection, which find just one reportItem per category,
|
|
7054
|
+
* this method will search for recursively for all matches
|
|
7055
|
+
*/
|
|
7056
|
+
sumByCategories(categories) {
|
|
7057
|
+
return this.getByCategories(categories).sumBy('amount');
|
|
7028
7058
|
}
|
|
7029
7059
|
/**
|
|
7030
7060
|
* Get collection of all report item details related to passed income source
|
|
@@ -7105,6 +7135,9 @@ var TaxReturnCategoryListEnum;
|
|
|
7105
7135
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["TAX_OFFSETS_MIDDLE"] = 62] = "TAX_OFFSETS_MIDDLE";
|
|
7106
7136
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["TAX_OFFSETS_SOLE"] = 63] = "TAX_OFFSETS_SOLE";
|
|
7107
7137
|
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["TAX_PAYABLE"] = 28] = "TAX_PAYABLE";
|
|
7138
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["BUSINESS_INCOME_OR_LOSS"] = 59] = "BUSINESS_INCOME_OR_LOSS";
|
|
7139
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["DEFERRED_BUSINESS_LOSSES_FROM_PRIOR_YEAR"] = 64] = "DEFERRED_BUSINESS_LOSSES_FROM_PRIOR_YEAR";
|
|
7140
|
+
TaxReturnCategoryListEnum[TaxReturnCategoryListEnum["DEFERRED_BUSINESS_LOSSES"] = 60] = "DEFERRED_BUSINESS_LOSSES";
|
|
7108
7141
|
})(TaxReturnCategoryListEnum || (TaxReturnCategoryListEnum = {}));
|
|
7109
7142
|
|
|
7110
7143
|
const TAX_RETURN_CATEGORIES = {
|
|
@@ -7190,10 +7223,15 @@ const TAX_RETURN_CATEGORIES = {
|
|
|
7190
7223
|
TaxReturnCategoryListEnum.RENT_EXPENSES,
|
|
7191
7224
|
TaxReturnCategoryListEnum.INTEREST_EXPENSES_WITHIN_AUSTRALIA,
|
|
7192
7225
|
TaxReturnCategoryListEnum.INTEREST_EXPENSES_OVERSEAS,
|
|
7193
|
-
TaxReturnCategoryListEnum.DEPRECIATION_EXPENSES,
|
|
7194
7226
|
TaxReturnCategoryListEnum.MOTOR_VEHICLE_EXPENSES,
|
|
7195
7227
|
TaxReturnCategoryListEnum.ALL_OTHER_EXPENSES
|
|
7196
7228
|
],
|
|
7229
|
+
depreciation: [
|
|
7230
|
+
TaxReturnCategoryListEnum.DEPRECIATION_EXPENSES,
|
|
7231
|
+
],
|
|
7232
|
+
loss: [
|
|
7233
|
+
TaxReturnCategoryListEnum.DEFERRED_BUSINESS_LOSSES_FROM_PRIOR_YEAR,
|
|
7234
|
+
],
|
|
7197
7235
|
taxOffsets: [
|
|
7198
7236
|
TaxReturnCategoryListEnum.TAX_OFFSETS_SOLE
|
|
7199
7237
|
],
|
|
@@ -9563,16 +9601,18 @@ class TaxSummary {
|
|
|
9563
9601
|
get soleNetCash() {
|
|
9564
9602
|
const income = this.sole.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.sole.income, TaxSummarySectionEnum.SOLE_TANK);
|
|
9565
9603
|
const expenses = this.sole.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.sole.expenses, TaxSummarySectionEnum.SOLE_TANK);
|
|
9566
|
-
return income
|
|
9604
|
+
return income + expenses;
|
|
9567
9605
|
}
|
|
9568
9606
|
/**
|
|
9569
9607
|
* Sole Net Total = Gross income - expenses
|
|
9570
9608
|
* https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/217677990/Dashboard+Main
|
|
9571
9609
|
*/
|
|
9572
9610
|
get soleNetTotal() {
|
|
9573
|
-
const income = this.sole.items.
|
|
9574
|
-
const expenses = this.sole.items.
|
|
9575
|
-
|
|
9611
|
+
const income = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.income);
|
|
9612
|
+
const expenses = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.expenses);
|
|
9613
|
+
const depreciation = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.expenses);
|
|
9614
|
+
const loss = this.sole.items.sumByCategories(TAX_RETURN_CATEGORIES.sole.loss);
|
|
9615
|
+
return income + expenses + depreciation - loss;
|
|
9576
9616
|
}
|
|
9577
9617
|
}
|
|
9578
9618
|
__decorate([
|
|
@@ -9923,8 +9963,9 @@ class SoleInvoiceService extends RestService {
|
|
|
9923
9963
|
this.isHydra = true;
|
|
9924
9964
|
}
|
|
9925
9965
|
updateStatus(invoice, status) {
|
|
9966
|
+
const updatedInvoice = Object.assign({}, invoice, { status });
|
|
9926
9967
|
// use id only to avoid unexpected changes
|
|
9927
|
-
return this.update(
|
|
9968
|
+
return this.update(updatedInvoice);
|
|
9928
9969
|
}
|
|
9929
9970
|
publish(invoice, document) {
|
|
9930
9971
|
// use id only to avoid unexpected changes
|