taxtank-core 0.23.10 → 0.24.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/taxtank-core.umd.js +457 -303
- package/bundles/taxtank-core.umd.js.map +1 -1
- package/esm2015/lib/collections/client-invite.collection.js +10 -0
- package/esm2015/lib/forms/index.js +2 -3
- package/esm2015/lib/forms/user/index.js +4 -0
- package/esm2015/lib/forms/user/user-invite.form.js +16 -0
- package/esm2015/lib/interceptors/basiq.interceptor.js +3 -3
- package/esm2015/lib/interceptors/corelogic-interceptor.js +3 -3
- package/esm2015/lib/interceptors/financial-year-interceptor.js +3 -3
- package/esm2015/lib/interceptors/interceptors.module.js +4 -4
- package/esm2015/lib/interceptors/jwt-interceptor.js +3 -3
- package/esm2015/lib/interceptors/preloader.interceptor.js +3 -3
- package/esm2015/lib/interceptors/user-switcher-interceptor.js +3 -3
- package/esm2015/lib/models/endpoint/endpoints.const.js +3 -1
- package/esm2015/lib/models/event/app-event-type.enum.js +13 -8
- package/esm2015/lib/services/account-setup/account-setup.service.js +3 -3
- package/esm2015/lib/services/asset/assets.service.js +3 -3
- package/esm2015/lib/services/auth/auth.service.js +3 -3
- package/esm2015/lib/services/auth/jwt.service.js +3 -3
- package/esm2015/lib/services/bank/bank-account-calculation.service.js +3 -3
- package/esm2015/lib/services/bank/bank-transaction-calculation.service.js +3 -3
- package/esm2015/lib/services/event/event-dispatcher.service.js +3 -3
- package/esm2015/lib/services/event/sse.service.js +3 -3
- package/esm2015/lib/services/export/export-formatter.service.js +3 -3
- package/esm2015/lib/services/header-title/header-title.service.js +3 -3
- package/esm2015/lib/services/http/address/address.service.js +3 -3
- package/esm2015/lib/services/http/bank/bank-account/bank-account.service.js +3 -3
- package/esm2015/lib/services/http/bank/bank-connection/bank-connection.service.js +3 -3
- package/esm2015/lib/services/http/bank/bank-transaction/bank-transaction.service.js +3 -3
- package/esm2015/lib/services/http/bank/bank.service.js +3 -3
- package/esm2015/lib/services/http/bank/basiq/basiq-token.service.js +3 -3
- package/esm2015/lib/services/http/bank/basiq/basiq.service.js +3 -3
- package/esm2015/lib/services/http/chart-accounts/chart-accounts-depreciations/chart-accounts-depreciations.service.js +3 -3
- package/esm2015/lib/services/http/chart-accounts/chart-accounts.service.js +3 -3
- package/esm2015/lib/services/http/chat/chat.service.js +3 -3
- package/esm2015/lib/services/http/chat/message/message.service.js +3 -3
- package/esm2015/lib/services/http/chat/message-document/message-document.service.js +3 -3
- package/esm2015/lib/services/http/depreciation/depreciation-capital-project/depreciation-capital-project.service.js +3 -3
- package/esm2015/lib/services/http/depreciation/depreciation.service.js +3 -3
- package/esm2015/lib/services/http/document/document-folder/document-folder.service.js +3 -3
- package/esm2015/lib/services/http/facebook/facebook.service.js +3 -3
- package/esm2015/lib/services/http/firm/client-income/client-income-types.service.js +3 -3
- package/esm2015/lib/services/http/firm/client-invite/client-invite.service.js +3 -3
- package/esm2015/lib/services/http/firm/client-movement/client-movement.service.js +3 -3
- package/esm2015/lib/services/http/firm/employee/employee.service.js +3 -3
- package/esm2015/lib/services/http/firm/employee-invite/employee-invite.service.js +3 -3
- package/esm2015/lib/services/http/firm/firm.service.js +3 -3
- package/esm2015/lib/services/http/firm/portfolio-report/client-portfolio-report.service.js +3 -3
- package/esm2015/lib/services/http/income-source/income-source-forecast/income-source-forecast.service.js +3 -3
- package/esm2015/lib/services/http/income-source/income-source.service.js +3 -3
- package/esm2015/lib/services/http/income-source/salary-forecast/salary-forecast.service.js +3 -3
- package/esm2015/lib/services/http/income-source/sole-forecast/sole-forecast.service.js +3 -3
- package/esm2015/lib/services/http/loan/borrowing-expense/borrowing-expense.service.js +3 -3
- package/esm2015/lib/services/http/loan/loan.service.js +3 -3
- package/esm2015/lib/services/http/property/property-category/property-category.service.js +3 -3
- package/esm2015/lib/services/http/property/property-category-movement/property-category-movement.service.js +3 -3
- package/esm2015/lib/services/http/property/property-document/property-document.service.js +3 -3
- package/esm2015/lib/services/http/property/property-sale/property-sale.service.js +3 -3
- package/esm2015/lib/services/http/property/property-sale/tax-exemption/tax-exemption.service.js +3 -3
- package/esm2015/lib/services/http/property/property-share/property-share.service.js +3 -3
- package/esm2015/lib/services/http/property/property.service.js +3 -3
- package/esm2015/lib/services/http/rest/rest.service.js +3 -3
- package/esm2015/lib/services/http/service-notification/service-notification.service.js +3 -3
- package/esm2015/lib/services/http/sole/sole-business/sole-business.service.js +3 -3
- package/esm2015/lib/services/http/sole/sole-contact/sole-contact.service.js +3 -3
- package/esm2015/lib/services/http/sole/sole-details/sole-details.service.js +3 -3
- package/esm2015/lib/services/http/subscription/service-price.service.js +3 -3
- package/esm2015/lib/services/http/subscription/subscription.service.js +3 -3
- package/esm2015/lib/services/http/tax-review/tax-review-history/tax-review-history.service.js +3 -3
- package/esm2015/lib/services/http/tax-review/tax-review.service.js +3 -3
- package/esm2015/lib/services/http/tax-summary/tax-summary.service.js +3 -3
- package/esm2015/lib/services/http/transaction/transaction-allocation/transaction-allocation.service.js +3 -3
- package/esm2015/lib/services/http/transaction/transaction-receipt/transaction-receipt.service.js +70 -0
- package/esm2015/lib/services/http/transaction/transaction.service.js +46 -30
- package/esm2015/lib/services/http/tutorial-video/tutorial-video.service.js +3 -3
- package/esm2015/lib/services/http/user/occupation/occupation.service.js +3 -3
- package/esm2015/lib/services/http/user/user-event-setting/user-event-setting.service.js +3 -3
- package/esm2015/lib/services/http/user/user-event-type/user-event-type.service.js +3 -3
- package/esm2015/lib/services/http/user/user.service.js +3 -3
- package/esm2015/lib/services/http/user/users-invite/users-invite.service.js +23 -0
- package/esm2015/lib/services/http/vehicle/vehicle-claim.service.js +3 -3
- package/esm2015/lib/services/http/vehicle/vehicle-logbook.service.js +3 -3
- package/esm2015/lib/services/http/vehicle/vehicle.service.js +3 -3
- package/esm2015/lib/services/intercom/intercom.service.js +3 -3
- package/esm2015/lib/services/kompassify/kompassify.service.js +3 -3
- package/esm2015/lib/services/pdf/pdf-from-dom-element/pdf-from-dom-element.service.js +3 -3
- package/esm2015/lib/services/pdf/pdf-from-table/pdf-from-data-table/pdf-from-data-table.service.js +3 -3
- package/esm2015/lib/services/pdf/pdf-from-table/pdf-from-html-table/pdf-from-html-table.service.js +3 -3
- package/esm2015/lib/services/pdf/pdf-from-table/pdf-from-table.service.js +3 -3
- package/esm2015/lib/services/preloader/preloader.service.js +3 -3
- package/esm2015/lib/services/property/corelogic/corelogic.service.js +3 -3
- package/esm2015/lib/services/property/equity-position-chart/equity-position-chart.service.js +3 -3
- package/esm2015/lib/services/property/property-calculation/property-calculation.service.js +3 -3
- package/esm2015/lib/services/report/property/property-transaction-report.service.js +3 -3
- package/esm2015/lib/services/toast/toast.service.js +3 -3
- package/esm2015/lib/services/transaction/transaction-calculation.service.js +3 -3
- package/esm2015/lib/services/user/user-switcher.service.js +3 -3
- package/esm2015/lib/services/xlsx/xlsx.service.js +3 -3
- package/esm2015/lib/tt-core.module.js +4 -4
- package/esm2015/public-api.js +3 -1
- package/fesm2015/taxtank-core.js +423 -301
- package/fesm2015/taxtank-core.js.map +1 -1
- package/lib/collections/client-invite.collection.d.ts +8 -0
- package/lib/forms/index.d.ts +1 -2
- package/lib/forms/user/index.d.ts +3 -0
- package/lib/forms/user/user-invite.form.d.ts +8 -0
- package/lib/models/event/app-event-type.enum.d.ts +12 -7
- package/lib/services/http/transaction/transaction-receipt/transaction-receipt.service.d.ts +28 -0
- package/lib/services/http/transaction/transaction.service.d.ts +12 -5
- package/lib/services/http/user/users-invite/users-invite.service.d.ts +13 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -97,9 +97,9 @@ export class SubscriptionService {
|
|
|
97
97
|
});
|
|
98
98
|
}
|
|
99
99
|
}
|
|
100
|
-
SubscriptionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
101
|
-
SubscriptionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.
|
|
102
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.
|
|
100
|
+
SubscriptionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: SubscriptionService, deps: [{ token: i1.HttpClient }, { token: i2.EventDispatcherService }, { token: i3.SseService }, { token: 'environment' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
101
|
+
SubscriptionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: SubscriptionService, providedIn: 'root' });
|
|
102
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: SubscriptionService, decorators: [{
|
|
103
103
|
type: Injectable,
|
|
104
104
|
args: [{
|
|
105
105
|
providedIn: 'root'
|
package/esm2015/lib/services/http/tax-review/tax-review-history/tax-review-history.service.js
CHANGED
|
@@ -29,9 +29,9 @@ export class TaxReviewHistoryService extends RestService {
|
|
|
29
29
|
});
|
|
30
30
|
}
|
|
31
31
|
}
|
|
32
|
-
TaxReviewHistoryService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
33
|
-
TaxReviewHistoryService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.
|
|
34
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.
|
|
32
|
+
TaxReviewHistoryService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TaxReviewHistoryService, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
|
|
33
|
+
TaxReviewHistoryService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TaxReviewHistoryService, providedIn: 'root' });
|
|
34
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TaxReviewHistoryService, decorators: [{
|
|
35
35
|
type: Injectable,
|
|
36
36
|
args: [{
|
|
37
37
|
providedIn: 'root'
|
|
@@ -83,9 +83,9 @@ export class TaxReviewService extends RestService {
|
|
|
83
83
|
});
|
|
84
84
|
}
|
|
85
85
|
}
|
|
86
|
-
TaxReviewService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
87
|
-
TaxReviewService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.
|
|
88
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.
|
|
86
|
+
TaxReviewService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TaxReviewService, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
|
|
87
|
+
TaxReviewService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TaxReviewService, providedIn: 'root' });
|
|
88
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TaxReviewService, decorators: [{
|
|
89
89
|
type: Injectable,
|
|
90
90
|
args: [{
|
|
91
91
|
providedIn: 'root'
|
|
@@ -57,9 +57,9 @@ export class TaxSummaryService {
|
|
|
57
57
|
});
|
|
58
58
|
}
|
|
59
59
|
}
|
|
60
|
-
TaxSummaryService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
61
|
-
TaxSummaryService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.
|
|
62
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.
|
|
60
|
+
TaxSummaryService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TaxSummaryService, deps: [{ token: i1.HttpClient }, { token: i2.EventDispatcherService }, { token: 'environment' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
61
|
+
TaxSummaryService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TaxSummaryService, providedIn: 'root' });
|
|
62
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TaxSummaryService, decorators: [{
|
|
63
63
|
type: Injectable,
|
|
64
64
|
args: [{
|
|
65
65
|
providedIn: 'root'
|
|
@@ -71,9 +71,9 @@ export class TransactionAllocationService extends RestService {
|
|
|
71
71
|
});
|
|
72
72
|
}
|
|
73
73
|
}
|
|
74
|
-
TransactionAllocationService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
75
|
-
TransactionAllocationService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.
|
|
76
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.
|
|
74
|
+
TransactionAllocationService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TransactionAllocationService, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
|
|
75
|
+
TransactionAllocationService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TransactionAllocationService, providedIn: 'root' });
|
|
76
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TransactionAllocationService, decorators: [{
|
|
77
77
|
type: Injectable,
|
|
78
78
|
args: [{
|
|
79
79
|
providedIn: 'root'
|
package/esm2015/lib/services/http/transaction/transaction-receipt/transaction-receipt.service.js
ADDED
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { Inject, Injectable } from '@angular/core';
|
|
2
|
+
import { TransactionReceipt } from '../../../../models/transaction/transaction-receipt';
|
|
3
|
+
import { plainToClass } from 'class-transformer';
|
|
4
|
+
import { AppEventTypeEnum } from '../../../../models/event/app-event-type.enum';
|
|
5
|
+
import { AppEvent } from '../../../../models/event/app-event';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/common/http";
|
|
8
|
+
import * as i2 from "../../../event/event-dispatcher.service";
|
|
9
|
+
export class TransactionReceiptService {
|
|
10
|
+
constructor(http, eventDispatcherService, environment) {
|
|
11
|
+
this.http = http;
|
|
12
|
+
this.eventDispatcherService = eventDispatcherService;
|
|
13
|
+
this.environment = environment;
|
|
14
|
+
this.url = 'receipts';
|
|
15
|
+
this.listenEvents();
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Transaction instance is necessary to take the ID and the receipt file from it.
|
|
19
|
+
*/
|
|
20
|
+
add(transaction) {
|
|
21
|
+
const formData = new FormData();
|
|
22
|
+
formData.append('file', transaction.file);
|
|
23
|
+
this.http.post(`${this.environment.apiV2}/transactions/${transaction.id}/${this.url}`, formData)
|
|
24
|
+
.subscribe((receiptResponse) => {
|
|
25
|
+
this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.TRANSACTION_RECEIPT_CREATED, plainToClass(TransactionReceipt, receiptResponse)));
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Transaction instance is necessary to take the ID and the receipt ID from it.
|
|
30
|
+
*/
|
|
31
|
+
delete(transaction) {
|
|
32
|
+
this.http.delete(`${this.environment.apiV2}/transactions/${transaction.id}/${this.url}/${transaction.receipt.id}`)
|
|
33
|
+
.subscribe(() => {
|
|
34
|
+
this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.TRANSACTION_RECEIPT_DELETED, transaction));
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
listenEvents() {
|
|
38
|
+
this.listenTransactionWithReceiptUpdated();
|
|
39
|
+
this.listenTransactionWithoutReceiptUpdated();
|
|
40
|
+
}
|
|
41
|
+
listenTransactionWithReceiptUpdated() {
|
|
42
|
+
this.eventDispatcherService.on([
|
|
43
|
+
AppEventTypeEnum.TRANSACTION_CREATED_WITH_NEW_RECEIPT,
|
|
44
|
+
AppEventTypeEnum.TRANSACTION_UPDATED_WITH_NEW_RECEIPT
|
|
45
|
+
]).subscribe((transaction) => {
|
|
46
|
+
this.add(transaction);
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Case when transaction was updated, but receipt was removed
|
|
51
|
+
*/
|
|
52
|
+
listenTransactionWithoutReceiptUpdated() {
|
|
53
|
+
this.eventDispatcherService.on(AppEventTypeEnum.TRANSACTION_UPDATED_WITH_DELETED_RECEIPT)
|
|
54
|
+
.subscribe((transaction) => {
|
|
55
|
+
this.delete(transaction);
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
TransactionReceiptService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TransactionReceiptService, deps: [{ token: i1.HttpClient }, { token: i2.EventDispatcherService }, { token: 'environment' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
60
|
+
TransactionReceiptService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TransactionReceiptService, providedIn: 'root' });
|
|
61
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TransactionReceiptService, decorators: [{
|
|
62
|
+
type: Injectable,
|
|
63
|
+
args: [{
|
|
64
|
+
providedIn: 'root'
|
|
65
|
+
}]
|
|
66
|
+
}], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i2.EventDispatcherService }, { type: undefined, decorators: [{
|
|
67
|
+
type: Inject,
|
|
68
|
+
args: ['environment']
|
|
69
|
+
}] }]; } });
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb24tcmVjZWlwdC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHQtY29yZS9zcmMvbGliL3NlcnZpY2VzL2h0dHAvdHJhbnNhY3Rpb24vdHJhbnNhY3Rpb24tcmVjZWlwdC90cmFuc2FjdGlvbi1yZWNlaXB0LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFbkQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sb0RBQW9ELENBQUM7QUFDeEYsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBSWpELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDhDQUE4QyxDQUFDO0FBQ2hGLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQzs7OztBQU05RCxNQUFNLE9BQU8seUJBQXlCO0lBR3BDLFlBQ1UsSUFBZ0IsRUFDaEIsc0JBQThDLEVBQ3ZCLFdBQWdCO1FBRnZDLFNBQUksR0FBSixJQUFJLENBQVk7UUFDaEIsMkJBQXNCLEdBQXRCLHNCQUFzQixDQUF3QjtRQUN2QixnQkFBVyxHQUFYLFdBQVcsQ0FBSztRQUxqRCxRQUFHLEdBQVcsVUFBVSxDQUFDO1FBT3ZCLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUN0QixDQUFDO0lBRUQ7O09BRUc7SUFDSCxHQUFHLENBQUMsV0FBd0I7UUFDMUIsTUFBTSxRQUFRLEdBQWEsSUFBSSxRQUFRLEVBQUUsQ0FBQztRQUMxQyxRQUFRLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFMUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssaUJBQWlCLFdBQVcsQ0FBQyxFQUFFLElBQUksSUFBSSxDQUFDLEdBQUcsRUFBRSxFQUFFLFFBQVEsQ0FBQzthQUM3RixTQUFTLENBQUMsQ0FBQyxlQUF1QyxFQUFFLEVBQUU7WUFDckQsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFFBQVEsQ0FBQyxJQUFJLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQywyQkFBMkIsRUFBRSxZQUFZLENBQUMsa0JBQWtCLEVBQUUsZUFBZSxDQUFDLENBQUMsQ0FBQyxDQUFBO1FBQ3JKLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVEOztPQUVHO0lBQ0gsTUFBTSxDQUFDLFdBQXdCO1FBQzdCLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLGlCQUFpQixXQUFXLENBQUMsRUFBRSxJQUFJLElBQUksQ0FBQyxHQUFHLElBQUksV0FBVyxDQUFDLE9BQU8sQ0FBQyxFQUFFLEVBQUUsQ0FBQzthQUMvRyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2QsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFFBQVEsQ0FBQyxJQUFJLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQywyQkFBMkIsRUFBRSxXQUFXLENBQUMsQ0FBQyxDQUFBO1FBQy9HLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFlBQVk7UUFDVixJQUFJLENBQUMsbUNBQW1DLEVBQUUsQ0FBQztRQUMzQyxJQUFJLENBQUMsc0NBQXNDLEVBQUUsQ0FBQztJQUNoRCxDQUFDO0lBRU8sbUNBQW1DO1FBQ3pDLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxFQUFFLENBQUM7WUFDN0IsZ0JBQWdCLENBQUMsb0NBQW9DO1lBQ3JELGdCQUFnQixDQUFDLG9DQUFvQztTQUN0RCxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsV0FBd0IsRUFBRSxFQUFFO1lBQ3hDLElBQUksQ0FBQyxHQUFHLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDeEIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQ7O09BRUc7SUFDSyxzQ0FBc0M7UUFDNUMsSUFBSSxDQUFDLHNCQUFzQixDQUFDLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyx3Q0FBd0MsQ0FBQzthQUN0RixTQUFTLENBQUMsQ0FBQyxXQUF3QixFQUFFLEVBQUU7WUFDdEMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUMzQixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7O3VIQXhEVSx5QkFBeUIsa0ZBTTFCLGFBQWE7MkhBTloseUJBQXlCLGNBRnhCLE1BQU07NEZBRVAseUJBQXlCO2tCQUhyQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQjs7MEJBT0ksTUFBTTsyQkFBQyxhQUFhIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0LCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUcmFuc2FjdGlvblJlY2VpcHQgYXMgVHJhbnNhY3Rpb25SZWNlaXB0QmFzZSB9IGZyb20gJy4uLy4uLy4uLy4uL2RiL01vZGVscy90cmFuc2FjdGlvbi90cmFuc2FjdGlvbi1yZWNlaXB0JztcbmltcG9ydCB7IFRyYW5zYWN0aW9uUmVjZWlwdCB9IGZyb20gJy4uLy4uLy4uLy4uL21vZGVscy90cmFuc2FjdGlvbi90cmFuc2FjdGlvbi1yZWNlaXB0JztcbmltcG9ydCB7IHBsYWluVG9DbGFzcyB9IGZyb20gJ2NsYXNzLXRyYW5zZm9ybWVyJztcbmltcG9ydCB7IFRyYW5zYWN0aW9uIH0gZnJvbSAnLi4vLi4vLi4vLi4vbW9kZWxzL3RyYW5zYWN0aW9uL3RyYW5zYWN0aW9uJztcbmltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBFdmVudERpc3BhdGNoZXJTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vZXZlbnQvZXZlbnQtZGlzcGF0Y2hlci5zZXJ2aWNlJztcbmltcG9ydCB7IEFwcEV2ZW50VHlwZUVudW0gfSBmcm9tICcuLi8uLi8uLi8uLi9tb2RlbHMvZXZlbnQvYXBwLWV2ZW50LXR5cGUuZW51bSc7XG5pbXBvcnQgeyBBcHBFdmVudCB9IGZyb20gJy4uLy4uLy4uLy4uL21vZGVscy9ldmVudC9hcHAtZXZlbnQnO1xuaW1wb3J0IHsgSUV2ZW50TGlzdGVuZXIgfSBmcm9tICcuLi8uLi8uLi8uLi9pbnRlcmZhY2VzL2V2ZW50LWxpc3RlbmVyLmludGVyZmFjZSc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIFRyYW5zYWN0aW9uUmVjZWlwdFNlcnZpY2UgaW1wbGVtZW50cyBJRXZlbnRMaXN0ZW5lciB7XG4gIHVybDogc3RyaW5nID0gJ3JlY2VpcHRzJztcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGh0dHA6IEh0dHBDbGllbnQsXG4gICAgcHJpdmF0ZSBldmVudERpc3BhdGNoZXJTZXJ2aWNlOiBFdmVudERpc3BhdGNoZXJTZXJ2aWNlLFxuICAgIEBJbmplY3QoJ2Vudmlyb25tZW50JykgcHJpdmF0ZSBlbnZpcm9ubWVudDogYW55XG4gICkge1xuICAgIHRoaXMubGlzdGVuRXZlbnRzKCk7XG4gIH1cblxuICAvKipcbiAgICogVHJhbnNhY3Rpb24gaW5zdGFuY2UgaXMgbmVjZXNzYXJ5IHRvIHRha2UgdGhlIElEIGFuZCB0aGUgcmVjZWlwdCBmaWxlIGZyb20gaXQuXG4gICAqL1xuICBhZGQodHJhbnNhY3Rpb246IFRyYW5zYWN0aW9uKTogdm9pZCB7XG4gICAgY29uc3QgZm9ybURhdGE6IEZvcm1EYXRhID0gbmV3IEZvcm1EYXRhKCk7XG4gICAgZm9ybURhdGEuYXBwZW5kKCdmaWxlJywgdHJhbnNhY3Rpb24uZmlsZSk7XG5cbiAgICB0aGlzLmh0dHAucG9zdChgJHt0aGlzLmVudmlyb25tZW50LmFwaVYyfS90cmFuc2FjdGlvbnMvJHt0cmFuc2FjdGlvbi5pZH0vJHt0aGlzLnVybH1gLCBmb3JtRGF0YSlcbiAgICAgIC5zdWJzY3JpYmUoKHJlY2VpcHRSZXNwb25zZTogVHJhbnNhY3Rpb25SZWNlaXB0QmFzZSkgPT4ge1xuICAgICAgICB0aGlzLmV2ZW50RGlzcGF0Y2hlclNlcnZpY2UuZGlzcGF0Y2gobmV3IEFwcEV2ZW50KEFwcEV2ZW50VHlwZUVudW0uVFJBTlNBQ1RJT05fUkVDRUlQVF9DUkVBVEVELCBwbGFpblRvQ2xhc3MoVHJhbnNhY3Rpb25SZWNlaXB0LCByZWNlaXB0UmVzcG9uc2UpKSlcbiAgICAgIH0pO1xuICB9XG5cbiAgLyoqXG4gICAqIFRyYW5zYWN0aW9uIGluc3RhbmNlIGlzIG5lY2Vzc2FyeSB0byB0YWtlIHRoZSBJRCBhbmQgdGhlIHJlY2VpcHQgSUQgZnJvbSBpdC5cbiAgICovXG4gIGRlbGV0ZSh0cmFuc2FjdGlvbjogVHJhbnNhY3Rpb24pOiB2b2lkIHtcbiAgICB0aGlzLmh0dHAuZGVsZXRlKGAke3RoaXMuZW52aXJvbm1lbnQuYXBpVjJ9L3RyYW5zYWN0aW9ucy8ke3RyYW5zYWN0aW9uLmlkfS8ke3RoaXMudXJsfS8ke3RyYW5zYWN0aW9uLnJlY2VpcHQuaWR9YClcbiAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICB0aGlzLmV2ZW50RGlzcGF0Y2hlclNlcnZpY2UuZGlzcGF0Y2gobmV3IEFwcEV2ZW50KEFwcEV2ZW50VHlwZUVudW0uVFJBTlNBQ1RJT05fUkVDRUlQVF9ERUxFVEVELCB0cmFuc2FjdGlvbikpXG4gICAgICB9KTtcbiAgfVxuXG4gIGxpc3RlbkV2ZW50cygpIHtcbiAgICB0aGlzLmxpc3RlblRyYW5zYWN0aW9uV2l0aFJlY2VpcHRVcGRhdGVkKCk7XG4gICAgdGhpcy5saXN0ZW5UcmFuc2FjdGlvbldpdGhvdXRSZWNlaXB0VXBkYXRlZCgpO1xuICB9XG5cbiAgcHJpdmF0ZSBsaXN0ZW5UcmFuc2FjdGlvbldpdGhSZWNlaXB0VXBkYXRlZCgpIHtcbiAgICB0aGlzLmV2ZW50RGlzcGF0Y2hlclNlcnZpY2Uub24oW1xuICAgICAgQXBwRXZlbnRUeXBlRW51bS5UUkFOU0FDVElPTl9DUkVBVEVEX1dJVEhfTkVXX1JFQ0VJUFQsXG4gICAgICBBcHBFdmVudFR5cGVFbnVtLlRSQU5TQUNUSU9OX1VQREFURURfV0lUSF9ORVdfUkVDRUlQVFxuICAgIF0pLnN1YnNjcmliZSgodHJhbnNhY3Rpb246IFRyYW5zYWN0aW9uKSA9PiB7XG4gICAgICB0aGlzLmFkZCh0cmFuc2FjdGlvbik7XG4gICAgfSk7XG4gIH1cblxuICAvKipcbiAgICogQ2FzZSB3aGVuIHRyYW5zYWN0aW9uIHdhcyB1cGRhdGVkLCBidXQgcmVjZWlwdCB3YXMgcmVtb3ZlZFxuICAgKi9cbiAgcHJpdmF0ZSBsaXN0ZW5UcmFuc2FjdGlvbldpdGhvdXRSZWNlaXB0VXBkYXRlZCgpIHtcbiAgICB0aGlzLmV2ZW50RGlzcGF0Y2hlclNlcnZpY2Uub24oQXBwRXZlbnRUeXBlRW51bS5UUkFOU0FDVElPTl9VUERBVEVEX1dJVEhfREVMRVRFRF9SRUNFSVBUKVxuICAgICAgLnN1YnNjcmliZSgodHJhbnNhY3Rpb246IFRyYW5zYWN0aW9uKSA9PiB7XG4gICAgICAgIHRoaXMuZGVsZXRlKHRyYW5zYWN0aW9uKTtcbiAgICAgIH0pO1xuICB9XG59XG4iXX0=
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { EventEmitter, Injectable } from '@angular/core';
|
|
1
|
+
import { EventEmitter, Inject, Injectable } from '@angular/core';
|
|
2
2
|
import { map } from 'rxjs/operators';
|
|
3
3
|
import { replace, sort } from '../../../functions/array';
|
|
4
4
|
import { enumToList } from '../../../functions/enum-to-list';
|
|
@@ -11,17 +11,25 @@ import { CHART_ACCOUNTS_CATEGORIES } from '../../../models/chart-accounts/chart-
|
|
|
11
11
|
import { Transaction } from '../../../models/transaction/transaction';
|
|
12
12
|
import { AppEventTypeEnum } from '../../../models/event/app-event-type.enum';
|
|
13
13
|
import { AppEvent } from '../../../models/event/app-event';
|
|
14
|
-
import { TransactionReceipt } from '../../../models/transaction/transaction-receipt';
|
|
15
14
|
import _ from 'lodash';
|
|
16
15
|
import { ChartAccountsTaxLabelsEnum } from '../../../models/chart-accounts/chart-accounts-tax-labels.enum';
|
|
17
16
|
import { PropertyCategoryListEnum } from '../../../db/Enums/property/property-category-list.enum';
|
|
18
17
|
import * as i0 from "@angular/core";
|
|
18
|
+
import * as i1 from "@angular/common/http";
|
|
19
|
+
import * as i2 from "../../event/event-dispatcher.service";
|
|
20
|
+
import * as i3 from "../../toast/toast.service";
|
|
21
|
+
import * as i4 from "./transaction-receipt/transaction-receipt.service";
|
|
19
22
|
/**
|
|
20
23
|
* Service for transactions business logic
|
|
21
24
|
*/
|
|
22
25
|
export class TransactionService extends RestService {
|
|
23
|
-
constructor() {
|
|
24
|
-
super(
|
|
26
|
+
constructor(http, eventDispatcherService, environment, toastService, transactionReceiptService) {
|
|
27
|
+
super(http, eventDispatcherService, environment, toastService);
|
|
28
|
+
this.http = http;
|
|
29
|
+
this.eventDispatcherService = eventDispatcherService;
|
|
30
|
+
this.environment = environment;
|
|
31
|
+
this.toastService = toastService;
|
|
32
|
+
this.transactionReceiptService = transactionReceiptService;
|
|
25
33
|
// url part for Transaction API
|
|
26
34
|
this.url = 'transactions';
|
|
27
35
|
this.modelClass = Transaction;
|
|
@@ -33,6 +41,8 @@ export class TransactionService extends RestService {
|
|
|
33
41
|
listenEvents() {
|
|
34
42
|
this.listenDepreciationChange();
|
|
35
43
|
this.listenPropertyShareUpdate();
|
|
44
|
+
this.listenReceiptAdded();
|
|
45
|
+
this.listenReceiptDeleted();
|
|
36
46
|
}
|
|
37
47
|
/**
|
|
38
48
|
* get list of all user's TaxTank transactions
|
|
@@ -123,11 +133,10 @@ export class TransactionService extends RestService {
|
|
|
123
133
|
transactions.forEach((transaction, index) => {
|
|
124
134
|
// @TODO backend: need to upload file in the same backend endpoint with transaction add/update
|
|
125
135
|
// check if passed receipt and upload file
|
|
126
|
-
// @TODO Alex: refactor. Move receipt to separated service and use event dispatcher to handle it
|
|
127
136
|
if (transaction.file && (transaction.file instanceof File)) {
|
|
128
137
|
transaction.id = response[index].id;
|
|
129
138
|
addedTransactions[index].file = transaction.file;
|
|
130
|
-
this.
|
|
139
|
+
this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.TRANSACTION_CREATED_WITH_NEW_RECEIPT, addedTransactions[index]));
|
|
131
140
|
}
|
|
132
141
|
// @TODO Viktor: implement API for saving of nested transactions
|
|
133
142
|
// add child transactions if exist
|
|
@@ -160,10 +169,13 @@ export class TransactionService extends RestService {
|
|
|
160
169
|
const updatedTransaction = plainToClass(Transaction, response);
|
|
161
170
|
// @TODO need to upload file in the same backend endpoint with transaction add/update
|
|
162
171
|
// check if passed new receipt and upload file
|
|
163
|
-
// @TODO Alex: refactor. Move receipt to separated service and use event dispatcher to handle it
|
|
164
172
|
if (transaction.file && (transaction.file instanceof File)) {
|
|
165
173
|
updatedTransaction.file = transaction.file;
|
|
166
|
-
this.
|
|
174
|
+
this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.TRANSACTION_UPDATED_WITH_NEW_RECEIPT, updatedTransaction));
|
|
175
|
+
// receipt file was removed from form - we should delete receipt from transaction
|
|
176
|
+
}
|
|
177
|
+
else if (!transaction.file && transaction.receipt) {
|
|
178
|
+
this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.TRANSACTION_UPDATED_WITH_DELETED_RECEIPT, updatedTransaction));
|
|
167
179
|
}
|
|
168
180
|
// @TODO Viktor: implement API for saving of nested transactions
|
|
169
181
|
if (transaction.transactions.length) {
|
|
@@ -233,23 +245,6 @@ export class TransactionService extends RestService {
|
|
|
233
245
|
this.transactionDeleted.emit(model);
|
|
234
246
|
}));
|
|
235
247
|
}
|
|
236
|
-
/**
|
|
237
|
-
* upload transaction receipt image
|
|
238
|
-
* @param transaction Еhe transaction for which the receipt will be imported
|
|
239
|
-
*/
|
|
240
|
-
uploadReceipt(transaction) {
|
|
241
|
-
const formData = new FormData();
|
|
242
|
-
formData.append('file', transaction.file);
|
|
243
|
-
transaction.receipt = null;
|
|
244
|
-
this.http.post(`${this.environment.apiV2}/${this.url}/${transaction.id}/receipts`, formData)
|
|
245
|
-
.subscribe((receiptResponse) => {
|
|
246
|
-
// we don't need to keep file after save
|
|
247
|
-
transaction.file = null;
|
|
248
|
-
transaction.receipt = plainToClass(TransactionReceipt, receiptResponse);
|
|
249
|
-
replace(this.cache, transaction);
|
|
250
|
-
this.updateCache();
|
|
251
|
-
});
|
|
252
|
-
}
|
|
253
248
|
/**
|
|
254
249
|
* calculate gross income amount based on transaction amount and taxes (fees)
|
|
255
250
|
* @param transaction Transaction instance for calculation
|
|
@@ -309,13 +304,34 @@ export class TransactionService extends RestService {
|
|
|
309
304
|
listenPropertyShareUpdate() {
|
|
310
305
|
this.eventDispatcherService.on(AppEventTypeEnum.PROPERTY_SHARE_UPDATED).subscribe(() => this.resetCache());
|
|
311
306
|
}
|
|
307
|
+
listenReceiptAdded() {
|
|
308
|
+
this.eventDispatcherService.on(AppEventTypeEnum.TRANSACTION_RECEIPT_CREATED).subscribe((transactionReceipt) => {
|
|
309
|
+
const transactionToUpdate = this.find(transactionReceipt.transaction.id);
|
|
310
|
+
// we don't need to keep file after save
|
|
311
|
+
transactionToUpdate.file = null;
|
|
312
|
+
transactionToUpdate.receipt = transactionReceipt;
|
|
313
|
+
replace(this.cache, transactionToUpdate);
|
|
314
|
+
this.updateCache();
|
|
315
|
+
});
|
|
316
|
+
}
|
|
317
|
+
listenReceiptDeleted() {
|
|
318
|
+
this.eventDispatcherService.on(AppEventTypeEnum.TRANSACTION_RECEIPT_DELETED).subscribe((transaction) => {
|
|
319
|
+
const transactionToUpdate = this.find(transaction.id);
|
|
320
|
+
transactionToUpdate.receipt = null;
|
|
321
|
+
replace(this.cache, transactionToUpdate);
|
|
322
|
+
this.updateCache();
|
|
323
|
+
});
|
|
324
|
+
}
|
|
312
325
|
}
|
|
313
|
-
TransactionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
314
|
-
TransactionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.
|
|
315
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.
|
|
326
|
+
TransactionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TransactionService, deps: [{ token: i1.HttpClient }, { token: i2.EventDispatcherService }, { token: 'environment' }, { token: i3.ToastService }, { token: i4.TransactionReceiptService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
327
|
+
TransactionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TransactionService, providedIn: 'root' });
|
|
328
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TransactionService, decorators: [{
|
|
316
329
|
type: Injectable,
|
|
317
330
|
args: [{
|
|
318
331
|
providedIn: 'root'
|
|
319
332
|
}]
|
|
320
|
-
}] }
|
|
321
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.service.js","sourceRoot":"","sources":["../../../../../../../projects/tt-core/src/lib/services/http/transaction/transaction.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAGzD,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAC7D,OAAO,EAAE,+BAA+B,EAAE,MAAM,uDAAuD,CAAC;AACxG,OAAO,EAAE,qCAAqC,EAAE,MAAM,8DAA8D,CAAC;AACrH,OAAO,EAAE,wBAAwB,EAAE,MAAM,8CAA8C,CAAC;AACxF,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,yBAAyB,EAAE,MAAM,gEAAgE,CAAC;AAC3G,OAAO,EAAE,WAAW,EAAE,MAAM,yCAAyC,CAAC;AACtE,OAAO,EAAE,gBAAgB,EAAE,MAAM,2CAA2C,CAAC;AAC7E,OAAO,EAAE,QAAQ,EAAE,MAAM,iCAAiC,CAAC;AAC3D,OAAO,EAAE,kBAAkB,EAAE,MAAM,iDAAiD,CAAC;AAErF,OAAO,CAAC,MAAM,QAAQ,CAAC;AACvB,OAAO,EAAE,0BAA0B,EAAE,MAAM,+DAA+D,CAAC;AAC3G,OAAO,EAAE,wBAAwB,EAAE,MAAM,wDAAwD,CAAC;;AAElG;;GAEG;AAIH,MAAM,OAAO,kBAAmB,SAAQ,WAAyC;IAHjF;;QAIE,+BAA+B;QAC/B,QAAG,GAAW,cAAc,CAAC;QAC7B,eAAU,GAAG,WAAW,CAAC;QACzB,uBAAkB,GAA8B,IAAI,YAAY,EAAe,CAAC;KA0VjF;IAxVC;;OAEG;IACH,YAAY;QACV,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAChC,IAAI,CAAC,yBAAyB,EAAE,CAAC;IACnC,CAAC;IAED;;OAEG;IACH,GAAG;QACD,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACf,sEAAsE;YACtE,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;YAChB,IAAI,CAAC,KAAK,EAAE;iBACT,SAAS,CAAC,CAAC,YAA2B,EAAE,EAAE;gBACzC,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC;gBAC1B,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,CAAC,CAAC,CAAC;SACN;QAED,OAAO,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC,IAAI;QAC1C,0DAA0D;QAC1D,GAAG,CAAC,CAAC,YAA2B,EAAiB,EAAE;YACjD,YAAY,CAAC,OAAO,CAAC,CAAC,WAAwB,EAAQ,EAAE;gBACtD,WAAW,CAAC,YAAY,GAAG,YAAY;oBACrC,iCAAiC;qBAChC,MAAM,CAAC,CAAC,CAAc,EAAW,EAAE,CAAC,CAAC,CAAC,iBAAiB,IAAI,CAAC,CAAC,iBAAiB,CAAC,EAAE,KAAK,WAAW,CAAC,EAAE,CAAC,CAAC;YAC3G,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;YAClC,OAAO,YAAY,CAAC;QACtB,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,GAAG,CAAC,KAAkB;QACpB,yDAAyD;QACzD,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,CAAC;aAC1B,IAAI,CACH,GAAG,CAAC,CAAC,eAA8B,EAAe,EAAE;YAClD,aAAa;YACb,IAAI,CAAC,sBAAsB,CAAC,QAAQ,CAClC,IAAI,QAAQ,CAAc,gBAAgB,CAAC,mBAAmB,EAAE,eAAe,CAAC,CAAC,CAAC,CAAC,CACpF,CAAC;YAEF,OAAO,eAAe,CAAC,CAAC,CAAC,CAAC;QAC5B,CAAC,CAAC,CACH,CAAC;IACN,CAAC;IAED;;OAEG;IACH,eAAe,CAAC,UAAkB;QAChC,OAAO,IAAI,CAAC,GAAG,EAAE;aACd,IAAI,CACH,GAAG,CAAC,CAAC,YAA2B,EAAiB,EAAE;YACjD,OAAO,YAAY,CAAC,MAAM,CAAC,CAAC,WAAwB,EAAW,EAAE;;gBAC/D,OAAO,CAAA,MAAA,WAAW,CAAC,QAAQ,0CAAE,EAAE,MAAK,UAAU,CAAC;YACjD,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CACH,CAAC;IACN,CAAC;IAED;;OAEG;IACH,mBAAmB;QACjB,OAAO,IAAI,CAAC,GAAG,EAAE;aACd,IAAI,CACH,GAAG,CAAC,CAAC,YAA2B,EAAiB,EAAE;YACjD,OAAO,YAAY,CAAC,MAAM,CAAC,CAAC,WAAwB,EAAW,EAAE,CAAC,WAAW,CAAC,UAAU,EAAE,CAAC,CAAC;QAC9F,CAAC,CAAC,CACH,CAAC;IACN,CAAC;IAED;;OAEG;IACH,uBAAuB,CAAC,UAAkB;QACxC,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAClB,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,IAAI,IAAI,CAAC,GAAG,eAAe,UAAU,uBAAuB,wBAAwB,CAAC,WAAW,EAAE,CAC5H;aACE,IAAI,CACH,GAAG,CAAC,CAAC,gBAAmC,EAAiB,EAAE;YACzD,OAAO,gBAAgB,CAAC,GAAG,CAAC,CAAC,eAAgC,EAAe,EAAE,CAAC,YAAY,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC,CAAC;QAC7H,CAAC,CAAC,CACH,CAAC;IACN,CAAC;IAED;;OAEG;IACH,0BAA0B;QACxB,OAAO,IAAI,CAAC,mBAAmB,EAAE;aAC9B,IAAI,CACH,GAAG,CAAC,CAAC,YAA2B,EAAiB,EAAE;YACjD,OAAO,YAAY,CAAC,MAAM,CAAC,CAAC,WAAwB,EAAW,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;QAC/G,CAAC,CAAC,CACH,CAAC;IACN,CAAC;IAED;;;OAGG;IACH,QAAQ,CAAC,YAA2B;QAClC,YAAY,GAAG,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QACzC,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,IAAI,IAAI,CAAC,GAAG,EAAE,EAAE,YAAY,CAAC;aACzE,IAAI,CACH,GAAG,CAAC,CAAC,QAA2B,EAAE,EAAE;YAClC,MAAM,iBAAiB,GAAkB,QAAQ,CAAC,GAAG,CAAC,CAAC,IAAqB,EAAE,EAAE,CAAC,YAAY,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,CAAC;YAElH,YAAY,CAAC,OAAO,CAAC,CAAC,WAAwB,EAAE,KAAa,EAAE,EAAE;gBAC/D,8FAA8F;gBAC9F,0CAA0C;gBAC1C,gGAAgG;gBAChG,IAAI,WAAW,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,YAAY,IAAI,CAAC,EAAE;oBAC1D,WAAW,CAAC,EAAE,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC;oBACpC,iBAAiB,CAAC,KAAK,CAAC,CAAC,IAAI,GAAG,WAAW,CAAC,IAAI,CAAC;oBACjD,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC;iBAC9C;gBAED,gEAAgE;gBAChE,kCAAkC;gBAClC,IAAI,WAAW,CAAC,YAAY,CAAC,MAAM,EAAE;oBACnC,WAAW,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,gBAA6B,EAAE,EAAE;wBACjE,gBAAgB,CAAC,iBAAiB,GAAG,YAAY,CAAC,WAAW,EAAE,EAAC,EAAE,EAAE,iBAAiB,CAAC,KAAK,CAAC,CAAC,EAAE,EAAC,CAAC,CAAC;oBACpG,CAAC,CAAC,CAAC;oBACH,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,SAAS,EAAE,CAAC;iBACrD;gBAED,oCAAoC;gBACpC,IAAI,WAAW,CAAC,SAAS,KAAK,wBAAwB,CAAC,QAAQ,EAAE;oBAC/D,iBAAiB,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;iBACvD;YACH,CAAC,CAAC,CAAC;YAEH,IAAI,IAAI,CAAC,KAAK,EAAE;gBACd,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,iBAAiB,CAAC,CAAC;gBACtC,IAAI,CAAC,WAAW,EAAE,CAAC;aACpB;YAED,IAAI,CAAC,sBAAsB,CAAC,QAAQ,CAClC,IAAI,QAAQ,CAAgB,gBAAgB,CAAC,oBAAoB,EAAE,iBAAiB,CAAC,CACtF,CAAC;YAEF,OAAO,iBAAiB,CAAC;QAC3B,CAAC,CAAC,CACH,CAAC;IACN,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,WAAwB;QAC7B,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,IAAI,IAAI,CAAC,GAAG,IAAI,WAAW,CAAC,EAAE,EAAE,EAAE,WAAW,CAAC;aACzF,IAAI,CACH,GAAG,CAAC,CAAC,QAAyB,EAAE,EAAE;YAChC,MAAM,kBAAkB,GAAgB,YAAY,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YAE5E,qFAAqF;YACrF,8CAA8C;YAC9C,gGAAgG;YAChG,IAAI,WAAW,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,YAAY,IAAI,CAAC,EAAE;gBAC1D,kBAAkB,CAAC,IAAI,GAAG,WAAW,CAAC,IAAI,CAAC;gBAC3C,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,CAAC;aACxC;YAED,gEAAgE;YAChE,IAAI,WAAW,CAAC,YAAY,CAAC,MAAM,EAAE;gBACnC,+CAA+C;gBAC/C,WAAW,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,gBAA6B,EAAE,EAAE;oBACjE,gBAAgB,CAAC,iBAAiB,GAAG,YAAY,CAAC,WAAW,EAAE,EAAC,EAAE,EAAE,kBAAkB,CAAC,EAAE,EAAC,CAAC,CAAC;gBAC9F,CAAC,CAAC,CAAC;gBACH,6EAA6E;gBAC7E,MAAM,yBAAyB,GAAkB,WAAW,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAc,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;gBAC3G,MAAM,sBAAsB,GAAkB,WAAW,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAc,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;gBAEzG,4BAA4B;gBAC5B,IAAI,yBAAyB,CAAC,MAAM,EAAE;oBACpC,IAAI,CAAC,WAAW,CAAC,yBAAyB,CAAC,CAAC,SAAS,EAAE,CAAC;iBACzD;gBAED,yBAAyB;gBACzB,IAAI,sBAAsB,CAAC,MAAM,EAAE;oBACjC,IAAI,CAAC,QAAQ,CAAC,sBAAsB,CAAC,CAAC,SAAS,EAAE,CAAC;iBACnD;aACF;YAED,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,kBAAkB,CAAC,CAAC;YACxC,IAAI,CAAC,WAAW,EAAE,CAAC;YAEnB,OAAO,kBAAkB,CAAC;QAC5B,CAAC,CAAC,CACH,CAAC;IACN,CAAC;IAED;;;OAGG;IACH,WAAW,CAAC,YAA2B;QACrC,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,IAAI,IAAI,CAAC,GAAG,EAAE,EAAE,YAAY,CAAC;aACxE,IAAI,CACH,GAAG,CAAC,CAAC,QAA2B,EAAE,EAAE;YAClC,MAAM,mBAAmB,GAAkB,QAAQ,CAAC,GAAG,CAAC,CAAC,IAAqB,EAAE,EAAE,CAAC,YAAY,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,CAAC;YAEpH,mBAAmB,CAAC,OAAO,CAAC,CAAC,kBAA+B,EAAE,EAAE;gBAC9D,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,kBAAkB,CAAC,CAAC;YAC1C,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,OAAO,mBAAmB,CAAC;QAC7B,CAAC,CAAC,CACH,CAAC;IACN,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,KAAkB;QACvB,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,IAAI,IAAI,CAAC,GAAG,IAAI,KAAK,CAAC,EAAE,EAAE,CAAC;aACzE,IAAI,CACH,GAAG,CAAC,GAAS,EAAE;YACb,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,WAAwB,EAAW,EAAE;;gBACnE,yDAAyD;gBACzD,IAAI,KAAK,CAAC,UAAU,EAAE;oBACpB,MAAM,GAAG,GAAa,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;oBAEjC,yCAAyC;oBACzC,IAAI,KAAK,CAAC,QAAQ,EAAE;wBAClB,+CAA+C;wBAC/C,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;qBAC7B;yBAAM;wBACL,kEAAkE;wBAClE,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAc,EAAW,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,KAAK,KAAK,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;qBACvF;oBAED,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;iBACtC;gBAED,OAAO,WAAW,CAAC,EAAE,KAAK,KAAK,CAAC,EAAE,IAAI,CAAA,MAAA,WAAW,CAAC,iBAAiB,0CAAE,EAAE,MAAK,KAAK,CAAC,EAAE,CAAC;YACvF,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,sBAAsB,CAAC,QAAQ,CAClC,IAAI,QAAQ,CAAc,gBAAgB,CAAC,mBAAmB,EAAE,KAAK,CAAC,CACvE,CAAC;YAEF,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACtC,CAAC,CAAC,CACH,CAAC;IACN,CAAC;IAED;;;OAGG;IACH,aAAa,CAAC,WAAwB;QACpC,MAAM,QAAQ,GAAa,IAAI,QAAQ,EAAE,CAAC;QAC1C,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;QAC1C,WAAW,CAAC,OAAO,GAAG,IAAI,CAAC;QAE3B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,IAAI,IAAI,CAAC,GAAG,IAAI,WAAW,CAAC,EAAE,WAAW,EAAE,QAAQ,CAAC;aACzF,SAAS,CAAC,CAAC,eAAoB,EAAE,EAAE;YAClC,wCAAwC;YACxC,WAAW,CAAC,IAAI,GAAG,IAAI,CAAC;YACxB,WAAW,CAAC,OAAO,GAAG,YAAY,CAAC,kBAAkB,EAAE,eAAe,CAAC,CAAC;YACxE,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;YACjC,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;OAGG;IACH,oBAAoB,CAAC,WAAwB;QAC3C,IAAI,MAAM,GAAW,WAAW,CAAC,MAAM,IAAI,CAAC,CAAC;QAE7C,sFAAsF;QACtF,IAAI,WAAW,CAAC,cAAc,EAAE,EAAE;YAChC,MAAM,IAAI,WAAW,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,GAAW,EAAE,IAAiB,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;SACrG;aAAM;YACL,2CAA2C;YAC3C,MAAM,IAAI,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;SAClC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;;OAGG;IACH,WAAW,CAAC,aAA4B;;QACtC,yEAAyE;QACzE,MAAM,oBAAoB,GAAa,UAAU,CAAC,+BAA+B,CAAC;aAC/E,GAAG,CAAC,CAAC,IAAsC,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/D,gFAAgF;QAChF,MAAM,uBAAuB,GAAa,UAAU,CAAC,qCAAqC,CAAC;aACxF,GAAG,CAAC,CAAC,IAAsC,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE/D,0FAA0F;QAC1F,0CAA0C;QAC1C,QAAQ,IAAI,EAAE;YACZ,KAAK,oBAAoB,CAAC,QAAQ,CAAC,MAAA,aAAa,CAAC,OAAO,0CAAE,EAAE,CAAC;gBAC3D,OAAO,0BAA0B,CAAC,QAAQ,CAAC;YAC7C,KAAK,uBAAuB,CAAC,QAAQ,CAAC,MAAA,aAAa,CAAC,OAAO,0CAAE,EAAE,CAAC;gBAC9D,OAAO,0BAA0B,CAAC,YAAY,CAAC;YACjD,KAAK,yBAAyB,CAAC,UAAU,CAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC;gBACxE,OAAO,0BAA0B,CAAC,YAAY,CAAC;YACjD;gBACE,OAAO,IAAI,CAAC;SACf;IACH,CAAC;IAED;;OAEG;IACK,wBAAwB;QAC9B,IAAI,CAAC,sBAAsB,CAAC,EAAE,CAAC,gBAAgB,CAAC,oBAAoB,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACnF,IAAI,CAAC,KAAK,EAAE;iBACT,SAAS,CAAC,CAAC,YAA2B,EAAE,EAAE;gBACzC,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC;gBAC1B,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACK,yBAAyB;QAC/B,IAAI,CAAC,sBAAsB,CAAC,EAAE,CAAC,gBAAgB,CAAC,sBAAsB,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;IAC7G,CAAC;;gHA7VU,kBAAkB;oHAAlB,kBAAkB,cAFjB,MAAM;4FAEP,kBAAkB;kBAH9B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { EventEmitter, Injectable } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { Transaction as TransactionBase } from '../../../db/Models/transaction/transaction';\nimport { map } from 'rxjs/operators';\nimport { replace, sort } from '../../../functions/array';\nimport { enumToList } from '../../../functions/enum-to-list';\nimport { ChartAccountsHeadingTaxableEnum } from '../../../db/Enums/chart-accounts-heading-taxable.enum';\nimport { ChartAccountsHeadingTaxDeductibleEnum } from '../../../db/Enums/chart-accounts-heading-tax-deductible.enum';\nimport { TransactionOperationEnum } from '../../../db/Enums/transaction-operation.enum';\nimport { RestService } from '../rest/rest.service';\nimport { plainToClass } from 'class-transformer';\nimport { CHART_ACCOUNTS_CATEGORIES } from '../../../models/chart-accounts/chart-accounts-categories.const';\nimport { Transaction } from '../../../models/transaction/transaction';\nimport { AppEventTypeEnum } from '../../../models/event/app-event-type.enum';\nimport { AppEvent } from '../../../models/event/app-event';\nimport { TransactionReceipt } from '../../../models/transaction/transaction-receipt';\nimport { ChartAccounts } from '../../../models/chart-accounts/chart-accounts';\nimport _ from 'lodash';\nimport { ChartAccountsTaxLabelsEnum } from '../../../models/chart-accounts/chart-accounts-tax-labels.enum';\nimport { PropertyCategoryListEnum } from '../../../db/Enums/property/property-category-list.enum';\n\n/**\n * Service for transactions business logic\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class TransactionService extends RestService<TransactionBase, Transaction> {\n  // url part for Transaction API\n  url: string = 'transactions';\n  modelClass = Transaction;\n  transactionDeleted: EventEmitter<Transaction> = new EventEmitter<Transaction>();\n\n  /**\n   * Listen events from Event Dispatcher services\n   */\n  listenEvents(): void {\n    this.listenDepreciationChange();\n    this.listenPropertyShareUpdate();\n  }\n\n  /**\n   * get list of all user's TaxTank transactions\n   */\n  get(): Observable<Transaction[]> {\n    if (!this.cache) {\n      // set cache as default empty array to avoid multiple backend requests\n      this.cache = [];\n      this.fetch()\n        .subscribe((transactions: Transaction[]) => {\n          this.cache = transactions;\n          this.updateCache();\n        });\n    }\n\n    return this.cacheSubject.asObservable().pipe(\n      // assign child transactions (fees) to parent transactions\n      map((transactions: Transaction[]): Transaction[] => {\n        transactions.forEach((transaction: Transaction): void => {\n          transaction.transactions = transactions\n            // get list of child transactions\n            .filter((t: Transaction): boolean => t.parentTransaction && t.parentTransaction.id === transaction.id);\n        });\n        sort(transactions, 'date', false);\n        return transactions;\n      })\n    );\n  }\n\n  /**\n   * Add single new transaction\n   * @param model New Transaction instance for saving\n   */\n  add(model: Transaction): Observable<Transaction> {\n    // we don't have POST API endpoint for single transaction\n    return this.addBatch([model])\n      .pipe(\n        map((newTransactions: Transaction[]): Transaction => {\n          // @TODO alex\n          this.eventDispatcherService.dispatch(\n            new AppEvent<Transaction>(AppEventTypeEnum.TRANSACTION_CREATED, newTransactions[0])\n          );\n\n          return newTransactions[0];\n        })\n      );\n  }\n\n  /**\n   * get transactions related with property\n   */\n  getByPropertyId(propertyId: number): Observable<Transaction[]> {\n    return this.get()\n      .pipe(\n        map((transactions: Transaction[]): Transaction[] => {\n          return transactions.filter((transaction: Transaction): boolean => {\n            return transaction.property?.id === propertyId;\n          });\n        })\n      );\n  }\n\n  /**\n   * get list of transactions with tank type 'Work'\n   */\n  getWorkTransactions(): Observable<Transaction[]> {\n    return this.get()\n      .pipe(\n        map((transactions: Transaction[]): Transaction[] => {\n          return transactions.filter((transaction: Transaction): boolean => transaction.isWorkTank());\n        })\n      );\n  }\n\n  /**\n   * Get list of property holding costs (transactions related to vacant land property)\n   */\n  getPropertyHoldingCosts(propertyId: number): Observable<Transaction[]> {\n    return this.http.get(\n      `${this.environment.apiV2}/${this.url}?propertyId=${propertyId}&propertyCategoryId=${PropertyCategoryListEnum.VACANT_LAND}`\n    )\n      .pipe(\n        map((transactionsBase: TransactionBase[]): Transaction[] => {\n          return transactionsBase.map((transactionBase: TransactionBase): Transaction => plainToClass(Transaction, transactionBase));\n        })\n      );\n  }\n\n  /**\n   * get list of taxable transactions with tank type 'Work'\n   */\n  getTaxableWorkTransactions(): Observable<Transaction[]> {\n    return this.getWorkTransactions()\n      .pipe(\n        map((transactions: Transaction[]): Transaction[] => {\n          return transactions.filter((transaction: Transaction): boolean => !!transaction.chartAccounts.taxReturnItem);\n        })\n      );\n  }\n\n  /**\n   * add multiple transactions\n   * @param transactions List of new Transaction instances for saving\n   */\n  addBatch(transactions: Transaction[]): Observable<Transaction[]> {\n    transactions = _.cloneDeep(transactions);\n    return this.http.post(`${this.environment.apiV2}/${this.url}`, transactions)\n      .pipe(\n        map((response: TransactionBase[]) => {\n          const addedTransactions: Transaction[] = response.map((item: TransactionBase) => plainToClass(Transaction, item));\n\n          transactions.forEach((transaction: Transaction, index: number) => {\n            // @TODO backend: need to upload file in the same backend endpoint with transaction add/update\n            // check if passed receipt and upload file\n            // @TODO Alex: refactor. Move receipt to separated service and use event dispatcher to handle it\n            if (transaction.file && (transaction.file instanceof File)) {\n              transaction.id = response[index].id;\n              addedTransactions[index].file = transaction.file;\n              this.uploadReceipt(addedTransactions[index]);\n            }\n\n            // @TODO Viktor: implement API for saving of nested transactions\n            // add child transactions if exist\n            if (transaction.transactions.length) {\n              transaction.transactions.forEach((childTransaction: Transaction) => {\n                childTransaction.parentTransaction = plainToClass(Transaction, {id: addedTransactions[index].id});\n              });\n              this.addBatch(transaction.transactions).subscribe();\n            }\n\n            // add transfer transaction to cache\n            if (transaction.operation === TransactionOperationEnum.TRANSFER) {\n              addedTransactions.push(addedTransactions[0].transfer);\n            }\n          });\n\n          if (this.cache) {\n            this.cache.push(...addedTransactions);\n            this.updateCache();\n          }\n\n          this.eventDispatcherService.dispatch(\n            new AppEvent<Transaction[]>(AppEventTypeEnum.TRANSACTIONS_CREATED, addedTransactions)\n          );\n\n          return addedTransactions;\n        })\n      );\n  }\n\n  /**\n   * update existing transaction\n   * @param transaction Transaction instance for updating\n   */\n  update(transaction: Transaction): Observable<Transaction> {\n    return this.http.put(`${this.environment.apiV2}/${this.url}/${transaction.id}`, transaction)\n      .pipe(\n        map((response: TransactionBase) => {\n          const updatedTransaction: Transaction = plainToClass(Transaction, response);\n\n          // @TODO need to upload file in the same backend endpoint with transaction add/update\n          // check if passed new receipt and upload file\n          // @TODO Alex: refactor. Move receipt to separated service and use event dispatcher to handle it\n          if (transaction.file && (transaction.file instanceof File)) {\n            updatedTransaction.file = transaction.file;\n            this.uploadReceipt(updatedTransaction);\n          }\n\n          // @TODO Viktor: implement API for saving of nested transactions\n          if (transaction.transactions.length) {\n            // add parent transaction to child transactions\n            transaction.transactions.forEach((childTransaction: Transaction) => {\n              childTransaction.parentTransaction = plainToClass(Transaction, {id: updatedTransaction.id});\n            });\n            // separate child transactions by id existing to define add or update action.\n            const childTransactionsToUpdate: Transaction[] = transaction.transactions.filter((t: Transaction) => t.id);\n            const childTransactionsToAdd: Transaction[] = transaction.transactions.filter((t: Transaction) => !t.id);\n\n            // update child transactions\n            if (childTransactionsToUpdate.length) {\n              this.updateBatch(childTransactionsToUpdate).subscribe();\n            }\n\n            // add child transactions\n            if (childTransactionsToAdd.length) {\n              this.addBatch(childTransactionsToAdd).subscribe();\n            }\n          }\n\n          replace(this.cache, updatedTransaction);\n          this.updateCache();\n\n          return updatedTransaction;\n        })\n      );\n  }\n\n  /**\n   * update multiple transactions\n   * @param transactions list of transactions for updating\n   */\n  updateBatch(transactions: Transaction[]): Observable<Transaction[]> {\n    return this.http.put(`${this.environment.apiV2}/${this.url}`, transactions)\n      .pipe(\n        map((response: TransactionBase[]) => {\n          const updatedTransactions: Transaction[] = response.map((item: TransactionBase) => plainToClass(Transaction, item));\n\n          updatedTransactions.forEach((updatedTransaction: Transaction) => {\n            replace(this.cache, updatedTransaction);\n          });\n\n          this.updateCache();\n          return updatedTransactions;\n        })\n      );\n  }\n\n  /**\n   * delete transaction and related transactions\n   * @param model\n   */\n  delete(model: Transaction): Observable<void> {\n    return this.http.delete(`${this.environment.apiV2}/${this.url}/${model.id}`)\n      .pipe(\n        map((): void => {\n          this.cache = this.cache.filter((transaction: Transaction): boolean => {\n            // when delete transfer we delete actually 2 transactions\n            if (model.isTransfer) {\n              const ids: number[] = [model.id];\n\n              // get id of related transfer transaction\n              if (model.transfer) {\n                // just take id if we delete source transaction\n                ids.push(model.transfer.id);\n              } else {\n                // find source transaction id if we delete destination transaction\n                ids.push(this.cache.find((t: Transaction): boolean => t.transfer.id === model.id).id);\n              }\n\n              return !ids.includes(transaction.id);\n            }\n\n            return transaction.id !== model.id && transaction.parentTransaction?.id !== model.id;\n          });\n\n          this.eventDispatcherService.dispatch(\n            new AppEvent<Transaction>(AppEventTypeEnum.TRANSACTION_DELETED, model)\n          );\n\n          this.updateCache();\n          this.transactionDeleted.emit(model);\n        })\n      );\n  }\n\n  /**\n   * upload transaction receipt image\n   * @param transaction Еhe transaction for which the receipt will be imported\n   */\n  uploadReceipt(transaction: Transaction): void {\n    const formData: FormData = new FormData();\n    formData.append('file', transaction.file);\n    transaction.receipt = null;\n\n    this.http.post(`${this.environment.apiV2}/${this.url}/${transaction.id}/receipts`, formData)\n      .subscribe((receiptResponse: any) => {\n        // we don't need to keep file after save\n        transaction.file = null;\n        transaction.receipt = plainToClass(TransactionReceipt, receiptResponse);\n        replace(this.cache, transaction);\n        this.updateCache();\n      });\n  }\n\n  /**\n   * calculate gross income amount based on transaction amount and taxes (fees)\n   * @param transaction Transaction instance for calculation\n   */\n  calculateGrossAmount(transaction: Transaction): number {\n    let amount: number = transaction.amount || 0;\n\n    // gross income amount includes amount of fees for property tank and tax for work tank\n    if (transaction.isPropertyTank()) {\n      amount += transaction.transactions.reduce((sum: number, item: Transaction) => sum + item.amount, 0);\n    } else {\n      // @TODO Alex: fix logic after TT-641 ready\n      amount += (transaction.tax || 0);\n    }\n\n    return amount;\n  }\n\n  /**\n   * get label for transaction tax field depended of selected chart account.\n   * tax type depends of chart account heading or category.\n   */\n  getTaxLabel(chartAccounts: ChartAccounts): ChartAccountsTaxLabelsEnum {\n    // get simple array of ids from enum with taxable chart accounts headings\n    const taxableCAHeadingsIds: number[] = enumToList(ChartAccountsHeadingTaxableEnum)\n      .map((item: { label: string, value: number }) => item.value);\n    // get simple array of ids from enum with tax deductible chart accounts headings\n    const deductibleCAHeadingsIds: number[] = enumToList(ChartAccountsHeadingTaxDeductibleEnum)\n      .map((item: { label: string, value: number }) => item.value);\n\n    // check if one of ids arrays includes current chart accounts heading id and set tax label\n    // otherwise label is empty for this class\n    switch (true) {\n      case taxableCAHeadingsIds.includes(chartAccounts.heading?.id):\n        return ChartAccountsTaxLabelsEnum.TAX_PAID;\n      case deductibleCAHeadingsIds.includes(chartAccounts.heading?.id):\n        return ChartAccountsTaxLabelsEnum.TAX_DEDUCTED;\n      case CHART_ACCOUNTS_CATEGORIES.workIncome.includes(chartAccounts.category):\n        return ChartAccountsTaxLabelsEnum.TAX_WITHHELD;\n      default:\n        return null;\n    }\n  }\n\n  /**\n   * Listen to EventDispatcherService event related to Depreciation changing\n   */\n  private listenDepreciationChange(): void {\n    this.eventDispatcherService.on(AppEventTypeEnum.DEPRECIATION_DELETED).subscribe(() => {\n      this.fetch()\n        .subscribe((transactions: Transaction[]) => {\n          this.cache = transactions;\n          this.updateCache();\n        });\n    });\n  }\n\n  /**\n   * Listen to EventDispatcherService event related to Property Share changing\n   */\n  private listenPropertyShareUpdate(): void {\n    this.eventDispatcherService.on(AppEventTypeEnum.PROPERTY_SHARE_UPDATED).subscribe(() => this.resetCache());\n  }\n}\n"]}
|
|
333
|
+
}], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i2.EventDispatcherService }, { type: undefined, decorators: [{
|
|
334
|
+
type: Inject,
|
|
335
|
+
args: ['environment']
|
|
336
|
+
}] }, { type: i3.ToastService }, { type: i4.TransactionReceiptService }]; } });
|
|
337
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.service.js","sourceRoot":"","sources":["../../../../../../../projects/tt-core/src/lib/services/http/transaction/transaction.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter, Inject, Injectable } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { Transaction as TransactionBase } from '../../../db/Models/transaction/transaction';\nimport { map } from 'rxjs/operators';\nimport { replace, sort } from '../../../functions/array';\nimport { enumToList } from '../../../functions/enum-to-list';\nimport { ChartAccountsHeadingTaxableEnum } from '../../../db/Enums/chart-accounts-heading-taxable.enum';\nimport { ChartAccountsHeadingTaxDeductibleEnum } from '../../../db/Enums/chart-accounts-heading-tax-deductible.enum';\nimport { TransactionOperationEnum } from '../../../db/Enums/transaction-operation.enum';\nimport { RestService } from '../rest/rest.service';\nimport { plainToClass } from 'class-transformer';\nimport { CHART_ACCOUNTS_CATEGORIES } from '../../../models/chart-accounts/chart-accounts-categories.const';\nimport { Transaction } from '../../../models/transaction/transaction';\nimport { AppEventTypeEnum } from '../../../models/event/app-event-type.enum';\nimport { AppEvent } from '../../../models/event/app-event';\nimport { TransactionReceipt } from '../../../models/transaction/transaction-receipt';\nimport { ChartAccounts } from '../../../models/chart-accounts/chart-accounts';\nimport _ from 'lodash';\nimport { ChartAccountsTaxLabelsEnum } from '../../../models/chart-accounts/chart-accounts-tax-labels.enum';\nimport { PropertyCategoryListEnum } from '../../../db/Enums/property/property-category-list.enum';\nimport { TransactionReceiptService } from './transaction-receipt/transaction-receipt.service';\nimport { HttpClient } from '@angular/common/http';\nimport { EventDispatcherService } from '../../event/event-dispatcher.service';\nimport { ToastService } from '../../toast/toast.service';\n\n/**\n * Service for transactions business logic\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class TransactionService extends RestService<TransactionBase, Transaction> {\n  // url part for Transaction API\n  url: string = 'transactions';\n  modelClass = Transaction;\n  transactionDeleted: EventEmitter<Transaction> = new EventEmitter<Transaction>();\n\n  constructor(\n    protected http: HttpClient,\n    protected eventDispatcherService: EventDispatcherService,\n    @Inject('environment') protected environment: any,\n    protected toastService: ToastService,\n    private transactionReceiptService: TransactionReceiptService\n  ) {\n    super(http, eventDispatcherService, environment, toastService);\n  }\n\n  /**\n   * Listen events from Event Dispatcher services\n   */\n  listenEvents(): void {\n    this.listenDepreciationChange();\n    this.listenPropertyShareUpdate();\n    this.listenReceiptAdded();\n    this.listenReceiptDeleted();\n  }\n\n  /**\n   * get list of all user's TaxTank transactions\n   */\n  get(): Observable<Transaction[]> {\n    if (!this.cache) {\n      // set cache as default empty array to avoid multiple backend requests\n      this.cache = [];\n      this.fetch()\n        .subscribe((transactions: Transaction[]) => {\n          this.cache = transactions;\n          this.updateCache();\n        });\n    }\n\n    return this.cacheSubject.asObservable().pipe(\n      // assign child transactions (fees) to parent transactions\n      map((transactions: Transaction[]): Transaction[] => {\n        transactions.forEach((transaction: Transaction): void => {\n          transaction.transactions = transactions\n            // get list of child transactions\n            .filter((t: Transaction): boolean => t.parentTransaction && t.parentTransaction.id === transaction.id);\n        });\n        sort(transactions, 'date', false);\n        return transactions;\n      })\n    );\n  }\n\n  /**\n   * Add single new transaction\n   * @param model New Transaction instance for saving\n   */\n  add(model: Transaction): Observable<Transaction> {\n    // we don't have POST API endpoint for single transaction\n    return this.addBatch([model])\n      .pipe(\n        map((newTransactions: Transaction[]): Transaction => {\n          // @TODO alex\n          this.eventDispatcherService.dispatch(\n            new AppEvent<Transaction>(AppEventTypeEnum.TRANSACTION_CREATED, newTransactions[0])\n          );\n\n          return newTransactions[0];\n        })\n      );\n  }\n\n  /**\n   * get transactions related with property\n   */\n  getByPropertyId(propertyId: number): Observable<Transaction[]> {\n    return this.get()\n      .pipe(\n        map((transactions: Transaction[]): Transaction[] => {\n          return transactions.filter((transaction: Transaction): boolean => {\n            return transaction.property?.id === propertyId;\n          });\n        })\n      );\n  }\n\n  /**\n   * get list of transactions with tank type 'Work'\n   */\n  getWorkTransactions(): Observable<Transaction[]> {\n    return this.get()\n      .pipe(\n        map((transactions: Transaction[]): Transaction[] => {\n          return transactions.filter((transaction: Transaction): boolean => transaction.isWorkTank());\n        })\n      );\n  }\n\n  /**\n   * Get list of property holding costs (transactions related to vacant land property)\n   */\n  getPropertyHoldingCosts(propertyId: number): Observable<Transaction[]> {\n    return this.http.get(\n      `${this.environment.apiV2}/${this.url}?propertyId=${propertyId}&propertyCategoryId=${PropertyCategoryListEnum.VACANT_LAND}`\n    )\n      .pipe(\n        map((transactionsBase: TransactionBase[]): Transaction[] => {\n          return transactionsBase.map((transactionBase: TransactionBase): Transaction => plainToClass(Transaction, transactionBase));\n        })\n      );\n  }\n\n  /**\n   * get list of taxable transactions with tank type 'Work'\n   */\n  getTaxableWorkTransactions(): Observable<Transaction[]> {\n    return this.getWorkTransactions()\n      .pipe(\n        map((transactions: Transaction[]): Transaction[] => {\n          return transactions.filter((transaction: Transaction): boolean => !!transaction.chartAccounts.taxReturnItem);\n        })\n      );\n  }\n\n  /**\n   * add multiple transactions\n   * @param transactions List of new Transaction instances for saving\n   */\n  addBatch(transactions: Transaction[]): Observable<Transaction[]> {\n    transactions = _.cloneDeep(transactions);\n    return this.http.post(`${this.environment.apiV2}/${this.url}`, transactions)\n      .pipe(\n        map((response: TransactionBase[]) => {\n          const addedTransactions: Transaction[] = response.map((item: TransactionBase) => plainToClass(Transaction, item));\n\n          transactions.forEach((transaction: Transaction, index: number) => {\n            // @TODO backend: need to upload file in the same backend endpoint with transaction add/update\n            // check if passed receipt and upload file\n            if (transaction.file && (transaction.file instanceof File)) {\n              transaction.id = response[index].id;\n              addedTransactions[index].file = transaction.file;\n              this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.TRANSACTION_CREATED_WITH_NEW_RECEIPT, addedTransactions[index]));\n            }\n\n            // @TODO Viktor: implement API for saving of nested transactions\n            // add child transactions if exist\n            if (transaction.transactions.length) {\n              transaction.transactions.forEach((childTransaction: Transaction) => {\n                childTransaction.parentTransaction = plainToClass(Transaction, {id: addedTransactions[index].id});\n              });\n              this.addBatch(transaction.transactions).subscribe();\n            }\n\n            // add transfer transaction to cache\n            if (transaction.operation === TransactionOperationEnum.TRANSFER) {\n              addedTransactions.push(addedTransactions[0].transfer);\n            }\n          });\n\n          if (this.cache) {\n            this.cache.push(...addedTransactions);\n            this.updateCache();\n          }\n\n          this.eventDispatcherService.dispatch(\n            new AppEvent<Transaction[]>(AppEventTypeEnum.TRANSACTIONS_CREATED, addedTransactions)\n          );\n\n          return addedTransactions;\n        })\n      );\n  }\n\n  /**\n   * update existing transaction\n   * @param transaction Transaction instance for updating\n   */\n  update(transaction: Transaction): Observable<Transaction> {\n    return this.http.put(`${this.environment.apiV2}/${this.url}/${transaction.id}`, transaction)\n      .pipe(\n        map((response: TransactionBase) => {\n          const updatedTransaction: Transaction = plainToClass(Transaction, response);\n\n          // @TODO need to upload file in the same backend endpoint with transaction add/update\n          // check if passed new receipt and upload file\n          if (transaction.file && (transaction.file instanceof File)) {\n            updatedTransaction.file = transaction.file;\n            this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.TRANSACTION_UPDATED_WITH_NEW_RECEIPT, updatedTransaction));\n            // receipt file was removed from form - we should delete receipt from transaction\n          } else if (!transaction.file && transaction.receipt) {\n            this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.TRANSACTION_UPDATED_WITH_DELETED_RECEIPT, updatedTransaction));\n          }\n\n          // @TODO Viktor: implement API for saving of nested transactions\n          if (transaction.transactions.length) {\n            // add parent transaction to child transactions\n            transaction.transactions.forEach((childTransaction: Transaction) => {\n              childTransaction.parentTransaction = plainToClass(Transaction, {id: updatedTransaction.id});\n            });\n            // separate child transactions by id existing to define add or update action.\n            const childTransactionsToUpdate: Transaction[] = transaction.transactions.filter((t: Transaction) => t.id);\n            const childTransactionsToAdd: Transaction[] = transaction.transactions.filter((t: Transaction) => !t.id);\n\n            // update child transactions\n            if (childTransactionsToUpdate.length) {\n              this.updateBatch(childTransactionsToUpdate).subscribe();\n            }\n\n            // add child transactions\n            if (childTransactionsToAdd.length) {\n              this.addBatch(childTransactionsToAdd).subscribe();\n            }\n          }\n\n          replace(this.cache, updatedTransaction);\n          this.updateCache();\n\n          return updatedTransaction;\n        })\n      );\n  }\n\n  /**\n   * update multiple transactions\n   * @param transactions list of transactions for updating\n   */\n  updateBatch(transactions: Transaction[]): Observable<Transaction[]> {\n    return this.http.put(`${this.environment.apiV2}/${this.url}`, transactions)\n      .pipe(\n        map((response: TransactionBase[]) => {\n          const updatedTransactions: Transaction[] = response.map((item: TransactionBase) => plainToClass(Transaction, item));\n\n          updatedTransactions.forEach((updatedTransaction: Transaction) => {\n            replace(this.cache, updatedTransaction);\n          });\n\n          this.updateCache();\n          return updatedTransactions;\n        })\n      );\n  }\n\n  /**\n   * delete transaction and related transactions\n   * @param model\n   */\n  delete(model: Transaction): Observable<void> {\n    return this.http.delete(`${this.environment.apiV2}/${this.url}/${model.id}`)\n      .pipe(\n        map((): void => {\n          this.cache = this.cache.filter((transaction: Transaction): boolean => {\n            // when delete transfer we delete actually 2 transactions\n            if (model.isTransfer) {\n              const ids: number[] = [model.id];\n\n              // get id of related transfer transaction\n              if (model.transfer) {\n                // just take id if we delete source transaction\n                ids.push(model.transfer.id);\n              } else {\n                // find source transaction id if we delete destination transaction\n                ids.push(this.cache.find((t: Transaction): boolean => t.transfer.id === model.id).id);\n              }\n\n              return !ids.includes(transaction.id);\n            }\n\n            return transaction.id !== model.id && transaction.parentTransaction?.id !== model.id;\n          });\n\n          this.eventDispatcherService.dispatch(\n            new AppEvent<Transaction>(AppEventTypeEnum.TRANSACTION_DELETED, model)\n          );\n\n          this.updateCache();\n          this.transactionDeleted.emit(model);\n        })\n      );\n  }\n\n  /**\n   * calculate gross income amount based on transaction amount and taxes (fees)\n   * @param transaction Transaction instance for calculation\n   */\n  calculateGrossAmount(transaction: Transaction): number {\n    let amount: number = transaction.amount || 0;\n\n    // gross income amount includes amount of fees for property tank and tax for work tank\n    if (transaction.isPropertyTank()) {\n      amount += transaction.transactions.reduce((sum: number, item: Transaction) => sum + item.amount, 0);\n    } else {\n      // @TODO Alex: fix logic after TT-641 ready\n      amount += (transaction.tax || 0);\n    }\n\n    return amount;\n  }\n\n  /**\n   * get label for transaction tax field depended of selected chart account.\n   * tax type depends of chart account heading or category.\n   */\n  getTaxLabel(chartAccounts: ChartAccounts): ChartAccountsTaxLabelsEnum {\n    // get simple array of ids from enum with taxable chart accounts headings\n    const taxableCAHeadingsIds: number[] = enumToList(ChartAccountsHeadingTaxableEnum)\n      .map((item: { label: string, value: number }) => item.value);\n    // get simple array of ids from enum with tax deductible chart accounts headings\n    const deductibleCAHeadingsIds: number[] = enumToList(ChartAccountsHeadingTaxDeductibleEnum)\n      .map((item: { label: string, value: number }) => item.value);\n\n    // check if one of ids arrays includes current chart accounts heading id and set tax label\n    // otherwise label is empty for this class\n    switch (true) {\n      case taxableCAHeadingsIds.includes(chartAccounts.heading?.id):\n        return ChartAccountsTaxLabelsEnum.TAX_PAID;\n      case deductibleCAHeadingsIds.includes(chartAccounts.heading?.id):\n        return ChartAccountsTaxLabelsEnum.TAX_DEDUCTED;\n      case CHART_ACCOUNTS_CATEGORIES.workIncome.includes(chartAccounts.category):\n        return ChartAccountsTaxLabelsEnum.TAX_WITHHELD;\n      default:\n        return null;\n    }\n  }\n\n  /**\n   * Listen to EventDispatcherService event related to Depreciation changing\n   */\n  private listenDepreciationChange(): void {\n    this.eventDispatcherService.on(AppEventTypeEnum.DEPRECIATION_DELETED).subscribe(() => {\n      this.fetch()\n        .subscribe((transactions: Transaction[]) => {\n          this.cache = transactions;\n          this.updateCache();\n        });\n    });\n  }\n\n  /**\n   * Listen to EventDispatcherService event related to Property Share changing\n   */\n  private listenPropertyShareUpdate(): void {\n    this.eventDispatcherService.on(AppEventTypeEnum.PROPERTY_SHARE_UPDATED).subscribe(() => this.resetCache());\n  }\n\n  private listenReceiptAdded() {\n    this.eventDispatcherService.on(AppEventTypeEnum.TRANSACTION_RECEIPT_CREATED).subscribe((transactionReceipt: TransactionReceipt) => {\n      const transactionToUpdate: Transaction = this.find(transactionReceipt.transaction.id);\n\n      // we don't need to keep file after save\n      transactionToUpdate.file = null;\n      transactionToUpdate.receipt = transactionReceipt;\n      replace(this.cache, transactionToUpdate);\n      this.updateCache();\n    });\n  }\n\n  private listenReceiptDeleted() {\n    this.eventDispatcherService.on(AppEventTypeEnum.TRANSACTION_RECEIPT_DELETED).subscribe((transaction: Transaction) => {\n      const transactionToUpdate: Transaction = this.find(transaction.id);\n\n      transactionToUpdate.receipt = null;\n      replace(this.cache, transactionToUpdate);\n      this.updateCache();\n    });\n  }\n}\n"]}
|
|
@@ -21,9 +21,9 @@ export class TutorialVideoService {
|
|
|
21
21
|
}
|
|
22
22
|
TutorialVideoService.googleUrl = `https://www.googleapis.com/drive/v3/files?fields=*&mimeType='video/mp4'&orderBy=name`;
|
|
23
23
|
TutorialVideoService.parents = '1uLMLzi8WUy2go9xhfzJEwgFwOM43dukM';
|
|
24
|
-
TutorialVideoService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
25
|
-
TutorialVideoService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.
|
|
26
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.
|
|
24
|
+
TutorialVideoService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TutorialVideoService, deps: [{ token: i1.HttpClient }, { token: 'environment' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
25
|
+
TutorialVideoService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TutorialVideoService, providedIn: 'root' });
|
|
26
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TutorialVideoService, decorators: [{
|
|
27
27
|
type: Injectable,
|
|
28
28
|
args: [{
|
|
29
29
|
providedIn: 'root'
|
|
@@ -31,9 +31,9 @@ export class OccupationService {
|
|
|
31
31
|
return this.occupationsSubject.asObservable();
|
|
32
32
|
}
|
|
33
33
|
}
|
|
34
|
-
OccupationService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
35
|
-
OccupationService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.
|
|
36
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.
|
|
34
|
+
OccupationService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: OccupationService, deps: [{ token: i1.HttpClient }, { token: 'environment' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
35
|
+
OccupationService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: OccupationService, providedIn: 'root' });
|
|
36
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: OccupationService, decorators: [{
|
|
37
37
|
type: Injectable,
|
|
38
38
|
args: [{
|
|
39
39
|
providedIn: 'root'
|
|
@@ -40,9 +40,9 @@ export class UserEventSettingService extends RestService {
|
|
|
40
40
|
}));
|
|
41
41
|
}
|
|
42
42
|
}
|
|
43
|
-
UserEventSettingService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
44
|
-
UserEventSettingService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.
|
|
45
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.
|
|
43
|
+
UserEventSettingService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: UserEventSettingService, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
|
|
44
|
+
UserEventSettingService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: UserEventSettingService, providedIn: 'root' });
|
|
45
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: UserEventSettingService, decorators: [{
|
|
46
46
|
type: Injectable,
|
|
47
47
|
args: [{
|
|
48
48
|
providedIn: 'root'
|
|
@@ -10,9 +10,9 @@ export class UserEventTypeService extends RestService {
|
|
|
10
10
|
this.isHydra = true;
|
|
11
11
|
}
|
|
12
12
|
}
|
|
13
|
-
UserEventTypeService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
14
|
-
UserEventTypeService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.
|
|
15
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.
|
|
13
|
+
UserEventTypeService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: UserEventTypeService, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
|
|
14
|
+
UserEventTypeService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: UserEventTypeService, providedIn: 'root' });
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: UserEventTypeService, decorators: [{
|
|
16
16
|
type: Injectable,
|
|
17
17
|
args: [{
|
|
18
18
|
providedIn: 'root'
|
|
@@ -145,9 +145,9 @@ export class UserService {
|
|
|
145
145
|
this.eventDispatcherService.on(AppEventTypeEnum.SERVICE_SUBSCRIPTION_UPDATED).subscribe(() => this.resetCache());
|
|
146
146
|
}
|
|
147
147
|
}
|
|
148
|
-
UserService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
149
|
-
UserService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.
|
|
150
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.
|
|
148
|
+
UserService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: UserService, deps: [{ token: i1.HttpClient }, { token: i2.JwtService }, { token: i3.EventDispatcherService }, { token: i4.SseService }, { token: 'environment' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
149
|
+
UserService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: UserService, providedIn: 'root' });
|
|
150
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: UserService, decorators: [{
|
|
151
151
|
type: Injectable,
|
|
152
152
|
args: [{
|
|
153
153
|
providedIn: 'root'
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { RestService } from '../../rest/rest.service';
|
|
3
|
+
import { RegistrationInvite } from '../../../../models/registration-invite/registration-invite';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
/**
|
|
6
|
+
* Service to work with invitations for unregistered users
|
|
7
|
+
*/
|
|
8
|
+
export class UsersInviteService extends RestService {
|
|
9
|
+
constructor() {
|
|
10
|
+
super(...arguments);
|
|
11
|
+
this.modelClass = RegistrationInvite;
|
|
12
|
+
this.url = 'users/invite';
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
UsersInviteService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: UsersInviteService, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
|
|
16
|
+
UsersInviteService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: UsersInviteService, providedIn: 'root' });
|
|
17
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: UsersInviteService, decorators: [{
|
|
18
|
+
type: Injectable,
|
|
19
|
+
args: [{
|
|
20
|
+
providedIn: 'root'
|
|
21
|
+
}]
|
|
22
|
+
}] });
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlcnMtaW52aXRlLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dC1jb3JlL3NyYy9saWIvc2VydmljZXMvaHR0cC91c2VyL3VzZXJzLWludml0ZS91c2Vycy1pbnZpdGUuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUV0RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw0REFBNEQsQ0FBQzs7QUFFaEc7O0dBRUc7QUFJSCxNQUFNLE9BQU8sa0JBQW1CLFNBQVEsV0FBdUQ7SUFIL0Y7O1FBSUUsZUFBVSxHQUE4QixrQkFBa0IsQ0FBQztRQUMzRCxRQUFHLEdBQVcsY0FBYyxDQUFDO0tBQzlCOztnSEFIWSxrQkFBa0I7b0hBQWxCLGtCQUFrQixjQUZqQixNQUFNOzRGQUVQLGtCQUFrQjtrQkFIOUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBSZXN0U2VydmljZSB9IGZyb20gJy4uLy4uL3Jlc3QvcmVzdC5zZXJ2aWNlJztcbmltcG9ydCB7IFJlZ2lzdHJhdGlvbkludml0ZSBhcyBSZWdpc3RyYXRpb25JbnZpdGVCYXNlIH0gZnJvbSAnLi4vLi4vLi4vLi4vZGIvTW9kZWxzL3VzZXIvcmVnaXN0cmF0aW9uLWludml0ZSc7XG5pbXBvcnQgeyBSZWdpc3RyYXRpb25JbnZpdGUgfSBmcm9tICcuLi8uLi8uLi8uLi9tb2RlbHMvcmVnaXN0cmF0aW9uLWludml0ZS9yZWdpc3RyYXRpb24taW52aXRlJztcblxuLyoqXG4gKiBTZXJ2aWNlIHRvIHdvcmsgd2l0aCBpbnZpdGF0aW9ucyBmb3IgdW5yZWdpc3RlcmVkIHVzZXJzXG4gKi9cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIFVzZXJzSW52aXRlU2VydmljZSBleHRlbmRzIFJlc3RTZXJ2aWNlPFJlZ2lzdHJhdGlvbkludml0ZUJhc2UsIFJlZ2lzdHJhdGlvbkludml0ZT4ge1xuICBtb2RlbENsYXNzOiB0eXBlb2YgUmVnaXN0cmF0aW9uSW52aXRlID0gUmVnaXN0cmF0aW9uSW52aXRlO1xuICB1cmw6IHN0cmluZyA9ICd1c2Vycy9pbnZpdGUnO1xufVxuIl19
|
|
@@ -13,9 +13,9 @@ export class VehicleClaimService extends RestService {
|
|
|
13
13
|
this.messageDeleted = MessagesEnum.VEHICLE_CLAIM_DELETED;
|
|
14
14
|
}
|
|
15
15
|
}
|
|
16
|
-
VehicleClaimService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
17
|
-
VehicleClaimService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.
|
|
18
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.
|
|
16
|
+
VehicleClaimService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: VehicleClaimService, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
|
|
17
|
+
VehicleClaimService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: VehicleClaimService, providedIn: 'root' });
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: VehicleClaimService, decorators: [{
|
|
19
19
|
type: Injectable,
|
|
20
20
|
args: [{
|
|
21
21
|
providedIn: 'root'
|
|
@@ -45,9 +45,9 @@ export class VehicleLogbookService {
|
|
|
45
45
|
}));
|
|
46
46
|
}
|
|
47
47
|
}
|
|
48
|
-
VehicleLogbookService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
49
|
-
VehicleLogbookService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.
|
|
50
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.
|
|
48
|
+
VehicleLogbookService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: VehicleLogbookService, deps: [{ token: i1.HttpClient }, { token: i2.EventDispatcherService }, { token: 'environment' }, { token: i3.ToastService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
49
|
+
VehicleLogbookService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: VehicleLogbookService, providedIn: 'root' });
|
|
50
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: VehicleLogbookService, decorators: [{
|
|
51
51
|
type: Injectable,
|
|
52
52
|
args: [{
|
|
53
53
|
providedIn: 'root'
|
|
@@ -62,9 +62,9 @@ export class VehicleService extends RestService {
|
|
|
62
62
|
});
|
|
63
63
|
}
|
|
64
64
|
}
|
|
65
|
-
VehicleService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.
|
|
66
|
-
VehicleService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.
|
|
67
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.
|
|
65
|
+
VehicleService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: VehicleService, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
|
|
66
|
+
VehicleService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: VehicleService, providedIn: 'root' });
|
|
67
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: VehicleService, decorators: [{
|
|
68
68
|
type: Injectable,
|
|
69
69
|
args: [{
|
|
70
70
|
providedIn: 'root'
|