taxtank-core 0.33.69 → 0.33.71

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.
@@ -11,8 +11,8 @@ export class DataService {
11
11
  createModelInstance(model) {
12
12
  return plainToClass(this.modelClass, model);
13
13
  }
14
- createCollectionInstance(collectionClass, items) {
15
- return new collectionClass(items);
14
+ createCollectionInstance(collectionClass, data) {
15
+ return new collectionClass(data.map((item) => this.createModelInstance(item)));
16
16
  }
17
17
  /**
18
18
  * never return cache directly to prevent update
@@ -30,7 +30,7 @@ export class DataService {
30
30
  * @TODO vik any[] because of problems with base models extending abstractModel
31
31
  */
32
32
  setCache(data) {
33
- this.cache = this.createCollectionInstance(this.collectionClass, data.map((item) => this.createModelInstance(item)));
33
+ this.cache = this.createCollectionInstance(this.collectionClass, data);
34
34
  }
35
35
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DataService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
36
36
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DataService, providedIn: 'root' }); }
@@ -41,4 +41,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
41
41
  providedIn: 'root'
42
42
  }]
43
43
  }] });
44
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHQtY29yZS9zcmMvbGliL3NlcnZpY2VzL2RhdGEuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUVqRCxPQUFPLEtBQUssTUFBTSxjQUFjLENBQUM7O0FBS2pDLE1BQU0sT0FBZ0IsV0FBVztJQWtCL0I7Ozs7T0FJRztJQUNPLG1CQUFtQixDQUFDLEtBQWE7UUFDekMsT0FBTyxZQUFZLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUM5QyxDQUFDO0lBRVMsd0JBQXdCLENBQUMsZUFBd0QsRUFBRSxLQUFjO1FBQ3pHLE9BQU8sSUFBSSxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDcEMsQ0FBQztJQUVEOztPQUVHO0lBQ0gsUUFBUTtRQUNOLE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMzQixDQUFDO0lBRUQ7O09BRUc7SUFDSCxhQUFhO1FBQ1gsT0FBTyxJQUFJLENBQUMsUUFBUSxFQUFFLEVBQUUsS0FBSyxDQUFDO0lBQ2hDLENBQUM7SUFFRDs7T0FFRztJQUNILFFBQVEsQ0FBQyxJQUFXO1FBQ2xCLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLHdCQUF3QixDQUN4QyxJQUFJLENBQUMsZUFBZSxFQUNwQixJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FDbkQsQ0FBQztJQUNKLENBQUM7K0dBckRtQixXQUFXO21IQUFYLFdBQVcsY0FGbkIsTUFBTTs7NEZBRUUsV0FBVztrQkFIaEMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb2xsZWN0aW9uIH0gZnJvbSAnLi4vY29sbGVjdGlvbnMnO1xuaW1wb3J0IHsgcGxhaW5Ub0NsYXNzIH0gZnJvbSAnY2xhc3MtdHJhbnNmb3JtZXInO1xuaW1wb3J0IHsgQWJzdHJhY3RNb2RlbCB9IGZyb20gJy4uL2RiL01vZGVscyc7XG5pbXBvcnQgY2xvbmUgZnJvbSAnbG9kYXNoL2Nsb25lJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgRGF0YVNlcnZpY2U8QmFzZU1vZGVsLCBNb2RlbCBleHRlbmRzIEFic3RyYWN0TW9kZWwsIENvbGxlY3Rpb25Nb2RlbCBleHRlbmRzIENvbGxlY3Rpb248TW9kZWw+PiB7XG4gIGRhdGE6IEJhc2VNb2RlbFtdO1xuXG4gIC8qKlxuICAgKiBNb2RlbCBjbGFzcyBmb3IgaW5zdGFuY2VzIGNyZWF0aW5nXG4gICAqL1xuICBhYnN0cmFjdCBtb2RlbENsYXNzO1xuXG4gIC8qKlxuICAgKiBDb2xsZWN0aW9uIE1vZGVsIGNsYXNzIGZvciBpbnN0YW5jZXMgY3JlYXRpbmdcbiAgICovXG4gIGFic3RyYWN0IGNvbGxlY3Rpb25DbGFzcztcblxuICAvKipcbiAgICogQ2FjaGVkIGFycmF5IG9mIHNlcnZpY2UgY2xhc3MgaW5zdGFuY2VzXG4gICAqL1xuICBwcm90ZWN0ZWQgY2FjaGU6IENvbGxlY3Rpb25Nb2RlbDtcblxuICAvKipcbiAgICogQFRPRE8gdXNlIGV4Y2x1ZGVFeHRyYW5lb3VzVmFsdWVzIHdoZW4gYWxsIG1vZGVscyByZWZhY3RvcmVkIChleHBvc2VkIGFsbCBuZWVkZWQgcHJvcGVydGllcylcbiAgICogQ3JlYXRlIG5ldyBpbnN0YW5jZSBvZiBjbGFzc1xuICAgKiBAcGFyYW0gbW9kZWwgU2luZ2xlIG9iamVjdCBvciBhcnJheSBmcm9tIHdoaWNoIHdpbGwgYmUgY3JlYXRlZCBtb2RlbCBpbnN0YW5jZShzKVxuICAgKi9cbiAgcHJvdGVjdGVkIGNyZWF0ZU1vZGVsSW5zdGFuY2UobW9kZWw6IG9iamVjdCk6IE1vZGVsIHtcbiAgICByZXR1cm4gcGxhaW5Ub0NsYXNzKHRoaXMubW9kZWxDbGFzcywgbW9kZWwpO1xuICB9XG5cbiAgcHJvdGVjdGVkIGNyZWF0ZUNvbGxlY3Rpb25JbnN0YW5jZShjb2xsZWN0aW9uQ2xhc3M6IG5ldyAoaXRlbXM6IE1vZGVsW10pID0+IENvbGxlY3Rpb25Nb2RlbCwgaXRlbXM6IE1vZGVsW10pOiBDb2xsZWN0aW9uTW9kZWwge1xuICAgIHJldHVybiBuZXcgY29sbGVjdGlvbkNsYXNzKGl0ZW1zKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBuZXZlciByZXR1cm4gY2FjaGUgZGlyZWN0bHkgdG8gcHJldmVudCB1cGRhdGVcbiAgICovXG4gIGdldENhY2hlKCk6IENvbGxlY3Rpb25Nb2RlbCB7XG4gICAgcmV0dXJuIGNsb25lKHRoaXMuY2FjaGUpO1xuICB9XG5cbiAgLyoqXG4gICAqIG5ldmVyIHJldHVybiBjYWNoZSBkaXJlY3RseSB0byBwcmV2ZW50IHVwZGF0ZVxuICAgKi9cbiAgZ2V0Q2FjaGVGaXJzdCgpOiBNb2RlbCB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0Q2FjaGUoKT8uZmlyc3Q7XG4gIH1cblxuICAvKipcbiAgICogQFRPRE8gdmlrIGFueVtdIGJlY2F1c2Ugb2YgcHJvYmxlbXMgd2l0aCBiYXNlIG1vZGVscyBleHRlbmRpbmcgYWJzdHJhY3RNb2RlbFxuICAgKi9cbiAgc2V0Q2FjaGUoZGF0YTogYW55W10pOiB2b2lkIHtcbiAgICB0aGlzLmNhY2hlID0gdGhpcy5jcmVhdGVDb2xsZWN0aW9uSW5zdGFuY2UoXG4gICAgICB0aGlzLmNvbGxlY3Rpb25DbGFzcyxcbiAgICAgIGRhdGEubWFwKChpdGVtKSA9PiB0aGlzLmNyZWF0ZU1vZGVsSW5zdGFuY2UoaXRlbSkpXG4gICAgKTtcbiAgfVxufVxuIl19
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHQtY29yZS9zcmMvbGliL3NlcnZpY2VzL2RhdGEuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUVqRCxPQUFPLEtBQUssTUFBTSxjQUFjLENBQUM7O0FBS2pDLE1BQU0sT0FBZ0IsV0FBVztJQWtCL0I7Ozs7T0FJRztJQUNPLG1CQUFtQixDQUFDLEtBQWE7UUFDekMsT0FBTyxZQUFZLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUM5QyxDQUFDO0lBRVMsd0JBQXdCLENBQUMsZUFBd0QsRUFBRSxJQUFXO1FBQ3RHLE9BQU8sSUFBSSxlQUFlLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNqRixDQUFDO0lBRUQ7O09BRUc7SUFDSCxRQUFRO1FBQ04sT0FBTyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzNCLENBQUM7SUFFRDs7T0FFRztJQUNILGFBQWE7UUFDWCxPQUFPLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRSxLQUFLLENBQUM7SUFDaEMsQ0FBQztJQUVEOztPQUVHO0lBQ0gsUUFBUSxDQUFDLElBQVc7UUFDbEIsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsd0JBQXdCLENBQUMsSUFBSSxDQUFDLGVBQWUsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUN6RSxDQUFDOytHQWxEbUIsV0FBVzttSEFBWCxXQUFXLGNBRm5CLE1BQU07OzRGQUVFLFdBQVc7a0JBSGhDLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29sbGVjdGlvbiB9IGZyb20gJy4uL2NvbGxlY3Rpb25zJztcbmltcG9ydCB7IHBsYWluVG9DbGFzcyB9IGZyb20gJ2NsYXNzLXRyYW5zZm9ybWVyJztcbmltcG9ydCB7IEFic3RyYWN0TW9kZWwgfSBmcm9tICcuLi9kYi9Nb2RlbHMnO1xuaW1wb3J0IGNsb25lIGZyb20gJ2xvZGFzaC9jbG9uZSc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIERhdGFTZXJ2aWNlPEJhc2VNb2RlbCwgTW9kZWwgZXh0ZW5kcyBBYnN0cmFjdE1vZGVsLCBDb2xsZWN0aW9uTW9kZWwgZXh0ZW5kcyBDb2xsZWN0aW9uPE1vZGVsPj4ge1xuICBkYXRhOiBCYXNlTW9kZWxbXTtcblxuICAvKipcbiAgICogTW9kZWwgY2xhc3MgZm9yIGluc3RhbmNlcyBjcmVhdGluZ1xuICAgKi9cbiAgYWJzdHJhY3QgbW9kZWxDbGFzcztcblxuICAvKipcbiAgICogQ29sbGVjdGlvbiBNb2RlbCBjbGFzcyBmb3IgaW5zdGFuY2VzIGNyZWF0aW5nXG4gICAqL1xuICBhYnN0cmFjdCBjb2xsZWN0aW9uQ2xhc3M7XG5cbiAgLyoqXG4gICAqIENhY2hlZCBhcnJheSBvZiBzZXJ2aWNlIGNsYXNzIGluc3RhbmNlc1xuICAgKi9cbiAgcHJvdGVjdGVkIGNhY2hlOiBDb2xsZWN0aW9uTW9kZWw7XG5cbiAgLyoqXG4gICAqIEBUT0RPIHVzZSBleGNsdWRlRXh0cmFuZW91c1ZhbHVlcyB3aGVuIGFsbCBtb2RlbHMgcmVmYWN0b3JlZCAoZXhwb3NlZCBhbGwgbmVlZGVkIHByb3BlcnRpZXMpXG4gICAqIENyZWF0ZSBuZXcgaW5zdGFuY2Ugb2YgY2xhc3NcbiAgICogQHBhcmFtIG1vZGVsIFNpbmdsZSBvYmplY3Qgb3IgYXJyYXkgZnJvbSB3aGljaCB3aWxsIGJlIGNyZWF0ZWQgbW9kZWwgaW5zdGFuY2UocylcbiAgICovXG4gIHByb3RlY3RlZCBjcmVhdGVNb2RlbEluc3RhbmNlKG1vZGVsOiBvYmplY3QpOiBNb2RlbCB7XG4gICAgcmV0dXJuIHBsYWluVG9DbGFzcyh0aGlzLm1vZGVsQ2xhc3MsIG1vZGVsKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBjcmVhdGVDb2xsZWN0aW9uSW5zdGFuY2UoY29sbGVjdGlvbkNsYXNzOiBuZXcgKGl0ZW1zOiBNb2RlbFtdKSA9PiBDb2xsZWN0aW9uTW9kZWwsIGRhdGE6IGFueVtdKTogQ29sbGVjdGlvbk1vZGVsIHtcbiAgICByZXR1cm4gbmV3IGNvbGxlY3Rpb25DbGFzcyhkYXRhLm1hcCgoaXRlbSkgPT4gdGhpcy5jcmVhdGVNb2RlbEluc3RhbmNlKGl0ZW0pKSk7XG4gIH1cblxuICAvKipcbiAgICogbmV2ZXIgcmV0dXJuIGNhY2hlIGRpcmVjdGx5IHRvIHByZXZlbnQgdXBkYXRlXG4gICAqL1xuICBnZXRDYWNoZSgpOiBDb2xsZWN0aW9uTW9kZWwge1xuICAgIHJldHVybiBjbG9uZSh0aGlzLmNhY2hlKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBuZXZlciByZXR1cm4gY2FjaGUgZGlyZWN0bHkgdG8gcHJldmVudCB1cGRhdGVcbiAgICovXG4gIGdldENhY2hlRmlyc3QoKTogTW9kZWwge1xuICAgIHJldHVybiB0aGlzLmdldENhY2hlKCk/LmZpcnN0O1xuICB9XG5cbiAgLyoqXG4gICAqIEBUT0RPIHZpayBhbnlbXSBiZWNhdXNlIG9mIHByb2JsZW1zIHdpdGggYmFzZSBtb2RlbHMgZXh0ZW5kaW5nIGFic3RyYWN0TW9kZWxcbiAgICovXG4gIHNldENhY2hlKGRhdGE6IGFueVtdKTogdm9pZCB7XG4gICAgdGhpcy5jYWNoZSA9IHRoaXMuY3JlYXRlQ29sbGVjdGlvbkluc3RhbmNlKHRoaXMuY29sbGVjdGlvbkNsYXNzLCBkYXRhKTtcbiAgfVxufVxuIl19
@@ -6,6 +6,7 @@ import { map } from 'rxjs/operators';
6
6
  import { plainToClass } from 'class-transformer';
7
7
  import { BankAccountStatusEnum } from '../../../../db/Enums';
8
8
  import { UserRolesEnum } from 'taxtank-core/common';
9
+ import { UserEventTypeTypeEnum } from '../../../../db/Enums/user-event-type-type.enum';
9
10
  import * as i0 from "@angular/core";
10
11
  import * as i1 from "@angular/common/http";
11
12
  import * as i2 from "../../../event";
@@ -34,10 +35,12 @@ export class BankAccountService extends RestService {
34
35
  */
35
36
  listenEvents() {
36
37
  this.listenToEventDispatcherChanges();
38
+ // @TODO why?
37
39
  this.listenCSE(BankTransaction, this.refreshCache, ['post', 'delete']);
38
40
  this.listenCSE(PropertyShare, this.refreshCache, ['put']);
39
41
  this.listenCSE(BankConnection, this.refreshCache, ['post']);
40
- this.listenConnections();
42
+ this.listenNotifications();
43
+ // this.listenConnections();
41
44
  }
42
45
  /**
43
46
  * Update bank account current balance
@@ -71,6 +74,19 @@ export class BankAccountService extends RestService {
71
74
  this.refreshCache();
72
75
  });
73
76
  }
77
+ listenNotifications() {
78
+ this.eventDispatcherService.on(AppEventTypeEnum.NOTIFICATION_ADDED).subscribe((notification) => {
79
+ const events = [
80
+ UserEventTypeTypeEnum.BASIQ_NEW_ACCOUNTS,
81
+ UserEventTypeTypeEnum.BASIQ_FIRST_IMPORT_COMPLETE,
82
+ UserEventTypeTypeEnum.BASIQ_AUTHORIZATION_FAIL,
83
+ ];
84
+ if (!notification.isRead && events.includes(notification.eventType)) {
85
+ // @TODO TT-3826 move to unified mercure event
86
+ this.refreshCache();
87
+ }
88
+ });
89
+ }
74
90
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BankAccountService, deps: [{ token: i1.HttpClient }, { token: i2.EventDispatcherService }, { token: i2.SseService }, { token: 'environment' }], target: i0.ɵɵFactoryTarget.Injectable }); }
75
91
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BankAccountService, providedIn: 'root' }); }
76
92
  }
@@ -83,4 +99,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
83
99
  type: Inject,
84
100
  args: ['environment']
85
101
  }] }] });
86
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFuay1hY2NvdW50LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dC1jb3JlL3NyYy9saWIvc2VydmljZXMvaHR0cC9iYW5rL2JhbmstYWNjb3VudC9iYW5rLWFjY291bnQuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUduRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsV0FBVyxFQUFFLGNBQWMsRUFBRSxlQUFlLEVBQUUsYUFBYSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDbkgsT0FBTyxFQUFjLFdBQVcsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUVyRCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBR2pELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzdELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7OztBQUVwRDs7R0FFRztBQUlILE1BQU0sT0FBTyxrQkFBbUIsU0FBUSxXQUFnRTtJQU90RyxZQUNZLElBQWdCLEVBQ2hCLHNCQUE4QyxFQUM5QyxVQUFzQixFQUNDLFdBQWdCO1FBRWpELEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUxULFNBQUksR0FBSixJQUFJLENBQVk7UUFDaEIsMkJBQXNCLEdBQXRCLHNCQUFzQixDQUF3QjtRQUM5QyxlQUFVLEdBQVYsVUFBVSxDQUFZO1FBQ0MsZ0JBQVcsR0FBWCxXQUFXLENBQUs7UUFWbkQsZ0JBQVcsR0FBRyxlQUFlLENBQUM7UUFDOUIsZUFBVSxHQUF1QixXQUFXLENBQUM7UUFDN0Msb0JBQWUsR0FBaUMscUJBQXFCLENBQUM7UUFDdEUsb0JBQWUsR0FBaUIsQ0FBQyxNQUFNLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxhQUFhLENBQUMsQ0FBQztRQUM5RSxVQUFLLEdBQUcsQ0FBQyxhQUFhLENBQUMsU0FBUyxFQUFFLGFBQWEsQ0FBQyxhQUFhLEVBQUUsYUFBYSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBU3RGLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUN0QixDQUFDO0lBRUQsU0FBUztRQUNQLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLEVBQUUscUJBQXFCLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDNUQsQ0FBQztJQUVEOztPQUVHO0lBQ0gsWUFBWTtRQUNWLElBQUksQ0FBQyw4QkFBOEIsRUFBRSxDQUFDO1FBQ3RDLElBQUksQ0FBQyxTQUFTLENBQUMsZUFBZSxFQUFFLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQyxNQUFNLEVBQUUsUUFBUSxDQUFDLENBQUMsQ0FBQztRQUN2RSxJQUFJLENBQUMsU0FBUyxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztRQUMxRCxJQUFJLENBQUMsU0FBUyxDQUFDLGNBQWMsRUFBRSxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztRQUM1RCxJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsb0JBQW9CLENBQUMsV0FBd0I7UUFDM0MsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNLElBQUksV0FBVyxDQUFDLEVBQUUsVUFBVSxFQUFFLFdBQVcsQ0FBQzthQUMxRSxJQUFJLENBQ0gsR0FBRyxDQUFDLENBQUMsUUFBZ0IsRUFBRSxFQUFFO1lBQ3ZCLE1BQU0sa0JBQWtCLEdBQWdCLFlBQVksQ0FBQyxXQUFXLEVBQUUsUUFBUSxDQUFDLENBQUM7WUFDNUUsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDLGtCQUFrQixDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUM7WUFFakQsT0FBTyxrQkFBa0IsQ0FBQztRQUM1QixDQUFDLENBQUMsQ0FDSCxDQUFDO0lBQ04sQ0FBQztJQUVEOztPQUVHO0lBQ0ssOEJBQThCO1FBQ3BDLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxFQUFFLENBQUM7WUFDN0IsZ0JBQWdCLENBQUMsbUJBQW1CO1lBQ3BDLGdCQUFnQixDQUFDLHVCQUF1QjtTQUN6QyxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUNoQixJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDdEIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0ssaUJBQWlCO1FBQ3ZCLElBQUksQ0FBQyxVQUFVLENBQUMsRUFBRSxDQUFDLGlCQUFpQixDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsVUFBOEIsRUFBUSxFQUFFO1lBQ3ZGLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztRQUN0QixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7K0dBcEVVLGtCQUFrQiw0R0FXbkIsYUFBYTttSEFYWixrQkFBa0IsY0FGakIsTUFBTTs7NEZBRVAsa0JBQWtCO2tCQUg5QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQjs7MEJBWUksTUFBTTsyQkFBQyxhQUFhIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0LCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBCYW5rQWNjb3VudCBhcyBCYW5rQWNjb3VudEJhc2UsIEJhbmtDb25uZWN0aW9uIGFzIEJhbmtDb25uZWN0aW9uQmFzZSB9IGZyb20gJy4uLy4uLy4uLy4uL2RiL01vZGVscyc7XG5pbXBvcnQgeyBBcHBFdmVudFR5cGVFbnVtLCBCYW5rQWNjb3VudCwgQmFua0Nvbm5lY3Rpb24sIEJhbmtUcmFuc2FjdGlvbiwgUHJvcGVydHlTaGFyZSB9IGZyb20gJy4uLy4uLy4uLy4uL21vZGVscyc7XG5pbXBvcnQgeyBSZXN0TWV0aG9kLCBSZXN0U2VydmljZSB9IGZyb20gJy4uLy4uL3Jlc3QnO1xuaW1wb3J0IHsgSUV2ZW50TGlzdGVuZXIgfSBmcm9tICcuLi8uLi8uLi8uLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IEJhbmtBY2NvdW50Q29sbGVjdGlvbiB9IGZyb20gJy4uLy4uLy4uLy4uL2NvbGxlY3Rpb25zJztcbmltcG9ydCB7IG1hcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7IHBsYWluVG9DbGFzcyB9IGZyb20gJ2NsYXNzLXRyYW5zZm9ybWVyJztcbmltcG9ydCB7IEV2ZW50RGlzcGF0Y2hlclNlcnZpY2UsIFNzZVNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9ldmVudCc7XG5pbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgQmFua0FjY291bnRTdGF0dXNFbnVtIH0gZnJvbSAnLi4vLi4vLi4vLi4vZGIvRW51bXMnO1xuaW1wb3J0IHsgVXNlclJvbGVzRW51bSB9IGZyb20gJ3RheHRhbmstY29yZS9jb21tb24nO1xuXG4vKipcbiAqIFNlcnZpY2UgdGhhdCBoYW5kbGluZyB1c2VyJ3MgYmFuayBhY2NvdW50cyBsb2dpY1xuICovXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBCYW5rQWNjb3VudFNlcnZpY2UgZXh0ZW5kcyBSZXN0U2VydmljZTxCYW5rQWNjb3VudEJhc2UsIEJhbmtBY2NvdW50LCBCYW5rQWNjb3VudENvbGxlY3Rpb24+IGltcGxlbWVudHMgSUV2ZW50TGlzdGVuZXIge1xuICBlbmRwb2ludFVyaSA9ICdiYW5rLWFjY291bnRzJztcbiAgbW9kZWxDbGFzczogdHlwZW9mIEJhbmtBY2NvdW50ID0gQmFua0FjY291bnQ7XG4gIGNvbGxlY3Rpb25DbGFzczogdHlwZW9mIEJhbmtBY2NvdW50Q29sbGVjdGlvbiA9IEJhbmtBY2NvdW50Q29sbGVjdGlvbjtcbiAgZGlzYWJsZWRNZXRob2RzOiBSZXN0TWV0aG9kW10gPSBbJ3Bvc3QnLCAncHV0QmF0Y2gnLCAnZGVsZXRlJywgJ2RlbGV0ZUJhdGNoJ107XG4gIHJvbGVzID0gW1VzZXJSb2xlc0VudW0uV09SS19UQU5LLCBVc2VyUm9sZXNFbnVtLlBST1BFUlRZX1RBTkssIFVzZXJSb2xlc0VudW0uU09MRV9UQU5LXTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcm90ZWN0ZWQgaHR0cDogSHR0cENsaWVudCxcbiAgICBwcm90ZWN0ZWQgZXZlbnREaXNwYXRjaGVyU2VydmljZTogRXZlbnREaXNwYXRjaGVyU2VydmljZSxcbiAgICBwcm90ZWN0ZWQgc3NlU2VydmljZTogU3NlU2VydmljZSxcbiAgICBASW5qZWN0KCdlbnZpcm9ubWVudCcpIHByb3RlY3RlZCBlbnZpcm9ubWVudDogYW55LFxuICApIHtcbiAgICBzdXBlcihlbnZpcm9ubWVudCk7XG4gICAgdGhpcy5saXN0ZW5FdmVudHMoKTtcbiAgfVxuXG4gIGdldEFjdGl2ZSgpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRCeSgnc3RhdHVzJywgQmFua0FjY291bnRTdGF0dXNFbnVtLkFDVElWRSk7XG4gIH1cblxuICAvKipcbiAgICogTGlzdGVuIHN5c3RlbSBub3RpZmljYXRpb25zIGFuZCB1cGRhdGUgY2FjaGUgd2hlbiBnb3QgYmFzaXEgbm90aWZpY2F0aW9uIHJlY2VpdmVkXG4gICAqL1xuICBsaXN0ZW5FdmVudHMoKTogdm9pZCB7XG4gICAgdGhpcy5saXN0ZW5Ub0V2ZW50RGlzcGF0Y2hlckNoYW5nZXMoKTtcbiAgICB0aGlzLmxpc3RlbkNTRShCYW5rVHJhbnNhY3Rpb24sIHRoaXMucmVmcmVzaENhY2hlLCBbJ3Bvc3QnLCAnZGVsZXRlJ10pO1xuICAgIHRoaXMubGlzdGVuQ1NFKFByb3BlcnR5U2hhcmUsIHRoaXMucmVmcmVzaENhY2hlLCBbJ3B1dCddKTtcbiAgICB0aGlzLmxpc3RlbkNTRShCYW5rQ29ubmVjdGlvbiwgdGhpcy5yZWZyZXNoQ2FjaGUsIFsncG9zdCddKTtcbiAgICB0aGlzLmxpc3RlbkNvbm5lY3Rpb25zKCk7XG4gIH1cblxuICAvKipcbiAgICogVXBkYXRlIGJhbmsgYWNjb3VudCBjdXJyZW50IGJhbGFuY2VcbiAgICogQFRPRE8gVmlrOiByZWZhY3RvciBvbmNlIGJhY2tlbmQgdXBkYXRlZCAoc2hvdWxkIGJlIHNlcGFyYXRlZCBlbmRwb2ludCBmb3IgQmFua0FjY291bnRCYWxhbmNlIGVudGl0eSlcbiAgICovXG4gIHVwZGF0ZUN1cnJlbnRCYWxhbmNlKGJhbmtBY2NvdW50OiBCYW5rQWNjb3VudCk6IE9ic2VydmFibGU8QmFua0FjY291bnQ+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwLnB1dChgJHt0aGlzLmFwaVVybH0vJHtiYW5rQWNjb3VudC5pZH0vYmFsYW5jZWAsIGJhbmtBY2NvdW50KVxuICAgICAgLnBpcGUoXG4gICAgICAgIG1hcCgocmVzcG9uc2U6IG9iamVjdCkgPT4ge1xuICAgICAgICAgIGNvbnN0IHVwZGF0ZWRCYW5rQWNjb3VudDogQmFua0FjY291bnQgPSBwbGFpblRvQ2xhc3MoQmFua0FjY291bnQsIHJlc3BvbnNlKTtcbiAgICAgICAgICB0aGlzLmhhbmRsZVJlc3BvbnNlKFt1cGRhdGVkQmFua0FjY291bnRdLCAncHV0Jyk7XG5cbiAgICAgICAgICByZXR1cm4gdXBkYXRlZEJhbmtBY2NvdW50O1xuICAgICAgICB9KVxuICAgICAgKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBMaXN0ZW4gdG8gRXZlbnREaXNwYXRjaGVyU2VydmljZSBldmVudHNcbiAgICovXG4gIHByaXZhdGUgbGlzdGVuVG9FdmVudERpc3BhdGNoZXJDaGFuZ2VzKCk6IHZvaWQge1xuICAgIHRoaXMuZXZlbnREaXNwYXRjaGVyU2VydmljZS5vbihbXG4gICAgICBBcHBFdmVudFR5cGVFbnVtLkxPQU5fUEFZT1VUX1VQREFURUQsXG4gICAgICBBcHBFdmVudFR5cGVFbnVtLkJBTktfVFJBTlNBQ1RJT05TX0FEREVEXG4gICAgXSkuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgIHRoaXMucmVmcmVzaENhY2hlKCk7XG4gICAgfSk7XG4gIH1cblxuICAvKipcbiAgICogQFRPRE8gcmVtb3ZlIHdoZW4gVFQtMzgyNiBpcyByZWFkeVxuICAgKiBtYW51YWxDb25uZWN0aW9uIG1vdmVkIHRvIGJhc2lxLCBvbGQgbWFudWFsIGJhbmtBY2NvdW50cyBjbG9zZWQgdG8gbGV0IHVzZXIgYWRkIGF1dG9tYXRlZCBiYW5rQWNjb3VudHMgKGJlY2F1c2UgdGhlcmUgaXMgbm8gcmVsaWFibGUgd2F5IHRvIG1lcmdlKVxuICAgKi9cbiAgcHJpdmF0ZSBsaXN0ZW5Db25uZWN0aW9ucygpOiB2b2lkIHtcbiAgICB0aGlzLnNzZVNlcnZpY2Uub24oYGJhbmtDb25uZWN0aW9uc2ApLnN1YnNjcmliZSgoY29ubmVjdGlvbjogQmFua0Nvbm5lY3Rpb25CYXNlKTogdm9pZCA9PiB7XG4gICAgICB0aGlzLnJlZnJlc2hDYWNoZSgpO1xuICAgIH0pO1xuICB9XG59XG4iXX0=
102
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bank-account.service.js","sourceRoot":"","sources":["../../../../../../../../../projects/tt-core/src/lib/services/http/bank/bank-account/bank-account.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { BankAccount as BankAccountBase, BankConnection as BankConnectionBase } from '../../../../db/Models';\nimport {\n  AppEventTypeEnum,\n  BankAccount,\n  BankConnection,\n  BankTransaction,\n  Notification,\n  PropertyShare\n} from '../../../../models';\nimport { RestMethod, RestService } from '../../rest';\nimport { IEventListener } from '../../../../interfaces';\nimport { BankAccountCollection } from '../../../../collections';\nimport { map } from 'rxjs/operators';\nimport { plainToClass } from 'class-transformer';\nimport { EventDispatcherService, SseService } from '../../../event';\nimport { HttpClient } from '@angular/common/http';\nimport { BankAccountStatusEnum } from '../../../../db/Enums';\nimport { UserRolesEnum } from 'taxtank-core/common';\nimport { UserEventTypeTypeEnum } from '../../../../db/Enums/user-event-type-type.enum';\n\n/**\n * Service that handling user's bank accounts logic\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class BankAccountService extends RestService<BankAccountBase, BankAccount, BankAccountCollection> implements IEventListener {\n  endpointUri = 'bank-accounts';\n  modelClass: typeof BankAccount = BankAccount;\n  collectionClass: typeof BankAccountCollection = BankAccountCollection;\n  disabledMethods: RestMethod[] = ['post', 'putBatch', 'delete', 'deleteBatch'];\n  roles = [UserRolesEnum.WORK_TANK, UserRolesEnum.PROPERTY_TANK, UserRolesEnum.SOLE_TANK];\n\n  constructor(\n    protected http: HttpClient,\n    protected eventDispatcherService: EventDispatcherService,\n    protected sseService: SseService,\n    @Inject('environment') protected environment: any,\n  ) {\n    super(environment);\n    this.listenEvents();\n  }\n\n  getActive() {\n    return this.getBy('status', BankAccountStatusEnum.ACTIVE);\n  }\n\n  /**\n   * Listen system notifications and update cache when got basiq notification received\n   */\n  listenEvents(): void {\n    this.listenToEventDispatcherChanges();\n    // @TODO why?\n    this.listenCSE(BankTransaction, this.refreshCache, ['post', 'delete']);\n    this.listenCSE(PropertyShare, this.refreshCache, ['put']);\n    this.listenCSE(BankConnection, this.refreshCache, ['post']);\n    this.listenNotifications();\n    // this.listenConnections();\n  }\n\n  /**\n   * Update bank account current balance\n   * @TODO Vik: refactor once backend updated (should be separated endpoint for BankAccountBalance entity)\n   */\n  updateCurrentBalance(bankAccount: BankAccount): Observable<BankAccount> {\n    return this.http.put(`${this.apiUrl}/${bankAccount.id}/balance`, bankAccount)\n      .pipe(\n        map((response: object) => {\n          const updatedBankAccount: BankAccount = plainToClass(BankAccount, response);\n          this.handleResponse([updatedBankAccount], 'put');\n\n          return updatedBankAccount;\n        })\n      );\n  }\n\n  /**\n   * Listen to EventDispatcherService events\n   */\n  private listenToEventDispatcherChanges(): void {\n    this.eventDispatcherService.on([\n      AppEventTypeEnum.LOAN_PAYOUT_UPDATED,\n      AppEventTypeEnum.BANK_TRANSACTIONS_ADDED\n    ]).subscribe(() => {\n      this.refreshCache();\n    });\n  }\n\n  /**\n   * @TODO remove when TT-3826 is ready\n   * manualConnection moved to basiq, old manual bankAccounts closed to let user add automated bankAccounts (because there is no reliable way to merge)\n   */\n  private listenConnections(): void {\n    this.sseService.on(`bankConnections`).subscribe((connection: BankConnectionBase): void => {\n      this.refreshCache();\n    });\n  }\n\n  private listenNotifications(): void {\n    this.eventDispatcherService.on(AppEventTypeEnum.NOTIFICATION_ADDED).subscribe((notification: Notification) => {\n      const events = [\n        UserEventTypeTypeEnum.BASIQ_NEW_ACCOUNTS,\n        UserEventTypeTypeEnum.BASIQ_FIRST_IMPORT_COMPLETE,\n        UserEventTypeTypeEnum.BASIQ_AUTHORIZATION_FAIL,\n      ];\n\n      if (!notification.isRead && events.includes(notification.eventType)) {\n        // @TODO TT-3826 move to unified mercure event\n        this.refreshCache();\n      }\n    });\n  }\n}\n"]}
@@ -2,10 +2,11 @@ import { Inject, Injectable } from '@angular/core';
2
2
  import { catchError, map } from 'rxjs/operators';
3
3
  import { plainToClass } from 'class-transformer';
4
4
  import { RestService } from '../../rest';
5
- import { BankConnection } from '../../../../models';
5
+ import { AppEventTypeEnum, BankConnection } from '../../../../models';
6
6
  import { throwError as observableThrowError } from 'rxjs';
7
7
  import { Collection } from '../../../../collections';
8
8
  import { BankConnectionMessagesEnum } from './bank-connection-messages.enum';
9
+ import { UserEventTypeTypeEnum } from '../../../../db/Enums/user-event-type-type.enum';
9
10
  import * as i0 from "@angular/core";
10
11
  /**
11
12
  * BankConnection means user account at specific bank (usually each user has only one at the same bank)
@@ -19,12 +20,10 @@ export class BankConnectionService extends RestService {
19
20
  this.collectionClass = Collection;
20
21
  this.endpointUri = 'bank-connections';
21
22
  this.disabledMethods = ['postBatch', 'putBatch', 'delete', 'deleteBatch'];
22
- this.mercureTopic = 'bankConnections';
23
23
  this.listenEvents();
24
24
  }
25
25
  listenEvents() {
26
- // @TODO remove when TT-3826 is ready
27
- this.listenSSE();
26
+ this.listenNotifications();
28
27
  }
29
28
  /**
30
29
  * there is no put BankConnection method, we have to post to update
@@ -67,6 +66,19 @@ export class BankConnectionService extends RestService {
67
66
  deactivate(bankConnection) {
68
67
  return this.put(bankConnection, `${this.apiUrl}/${bankConnection.id}/deactivate`);
69
68
  }
69
+ listenNotifications() {
70
+ this.eventDispatcherService.on(AppEventTypeEnum.NOTIFICATION_ADDED).subscribe((notification) => {
71
+ const events = [
72
+ UserEventTypeTypeEnum.BASIQ_NEW_ACCOUNTS,
73
+ UserEventTypeTypeEnum.BASIQ_FIRST_IMPORT_COMPLETE,
74
+ UserEventTypeTypeEnum.BASIQ_AUTHORIZATION_FAIL,
75
+ ];
76
+ if (!notification.isRead && events.includes(notification.eventType)) {
77
+ // @TODO TT-3826 move to unified mercure event
78
+ this.refreshCache();
79
+ }
80
+ });
81
+ }
70
82
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BankConnectionService, deps: [{ token: 'environment' }], target: i0.ɵɵFactoryTarget.Injectable }); }
71
83
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BankConnectionService, providedIn: 'root' }); }
72
84
  }
@@ -79,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
79
91
  type: Inject,
80
92
  args: ['environment']
81
93
  }] }] });
82
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFuay1jb25uZWN0aW9uLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dC1jb3JlL3NyYy9saWIvc2VydmljZXMvaHR0cC9iYW5rL2JhbmstY29ubmVjdGlvbi9iYW5rLWNvbm5lY3Rpb24uc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVuRCxPQUFPLEVBQUUsVUFBVSxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRWpELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNqRCxPQUFPLEVBQWMsV0FBVyxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBQ3JELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUdwRCxPQUFPLEVBQUUsVUFBVSxJQUFJLG9CQUFvQixFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzFELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNyRCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQzs7QUFFN0U7OztHQUdHO0FBSUgsTUFBTSxPQUFPLHFCQUFzQixTQUFRLFdBQTJFO0lBT3BILFlBQTZDLFdBQWdCO1FBQzNELEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUR3QixnQkFBVyxHQUFYLFdBQVcsQ0FBSztRQU43RCxlQUFVLEdBQTBCLGNBQWMsQ0FBQztRQUNuRCxvQkFBZSxHQUFzQixVQUFVLENBQUM7UUFDaEQsZ0JBQVcsR0FBRyxrQkFBa0IsQ0FBQztRQUNqQyxvQkFBZSxHQUFpQixDQUFDLFdBQVcsRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLGFBQWEsQ0FBQyxDQUFDO1FBQ25GLGlCQUFZLEdBQUcsaUJBQWlCLENBQUM7UUFJL0IsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3RCLENBQUM7SUFFRCxZQUFZO1FBQ1YscUNBQXFDO1FBQ3JDLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztJQUNuQixDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsSUFBSSxDQUFDLGNBQThCO1FBQ2pDLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxjQUFjLENBQUM7YUFDL0MsSUFBSSxDQUNILEdBQUcsQ0FBQyxDQUFDLFFBQTRCLEVBQUUsRUFBRTtZQUNuQyxNQUFNLE1BQU0sR0FBRyxZQUFZLENBQUMsY0FBYyxFQUFFLFFBQVEsQ0FBQyxDQUFDO1lBRXRELCtEQUErRDtZQUMvRCxJQUFJLE1BQU0sQ0FBQyxPQUFPLEVBQUUsRUFBRTtnQkFDcEIsUUFBUSxJQUFJLEVBQUU7b0JBQ1osS0FBSyxNQUFNLENBQUMsY0FBYyxFQUFFO3dCQUMxQixJQUFJLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQywwQkFBMEIsQ0FBQyxhQUFhLENBQUMsQ0FBQzt3QkFDcEUsTUFBTTtvQkFDUixLQUFLLE1BQU0sQ0FBQyxtQkFBbUIsRUFBRTt3QkFDL0IsSUFBSSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsMEJBQTBCLENBQUMsa0JBQWtCLENBQUMsQ0FBQzt3QkFDekUsTUFBTTtpQkFDVDthQUNGO1lBRUQsT0FBTyxNQUFNLENBQUM7UUFDaEIsQ0FBQyxDQUFDLEVBQ0YsVUFBVSxDQUFDLENBQUMsS0FBd0IsRUFBRSxFQUFFO1lBQ3RDLGlEQUFpRDtZQUNqRCxJQUFJLEtBQUssQ0FBQyxNQUFNLEtBQUssR0FBRyxFQUFFO2dCQUN4QixJQUFJLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQywwQkFBMEIsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO2FBQ3pFO1lBRUQseUVBQXlFO1lBQ3pFLElBQUksS0FBSyxDQUFDLE1BQU0sS0FBSyxHQUFHLEVBQUU7Z0JBQ3hCLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLDBCQUEwQixDQUFDLGdCQUFnQixDQUFDLENBQUM7YUFDdEU7WUFFRCxJQUFJLEtBQUssQ0FBQyxNQUFNLEtBQUssR0FBRyxFQUFFO2dCQUN4QixJQUFJLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQywwQkFBMEIsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO2FBQzNFO1lBRUQsT0FBTyxvQkFBb0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNyQyxDQUFDLENBQUMsQ0FDSCxDQUFBO0lBQ0wsQ0FBQztJQUVELFFBQVEsQ0FBQyxjQUE4QjtRQUNyQyxPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsY0FBYyxFQUFFLEdBQUcsSUFBSSxDQUFDLE1BQU0sSUFBSSxjQUFjLENBQUMsRUFBRSxXQUFXLENBQUMsQ0FBQztJQUNsRixDQUFDO0lBRUQsVUFBVSxDQUFDLGNBQThCO1FBQ3ZDLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxjQUFjLEVBQUUsR0FBRyxJQUFJLENBQUMsTUFBTSxJQUFJLGNBQWMsQ0FBQyxFQUFFLGFBQWEsQ0FBQyxDQUFDO0lBQ3BGLENBQUM7K0dBbkVVLHFCQUFxQixrQkFPWixhQUFhO21IQVB0QixxQkFBcUIsY0FGcEIsTUFBTTs7NEZBRVAscUJBQXFCO2tCQUhqQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQjs7MEJBUWMsTUFBTTsyQkFBQyxhQUFhIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0LCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBjYXRjaEVycm9yLCBtYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBCYW5rQ29ubmVjdGlvbiBhcyBCYW5rQ29ubmVjdGlvbkJhc2UgfSBmcm9tICcuLi8uLi8uLi8uLi9kYi9Nb2RlbHMnO1xuaW1wb3J0IHsgcGxhaW5Ub0NsYXNzIH0gZnJvbSAnY2xhc3MtdHJhbnNmb3JtZXInO1xuaW1wb3J0IHsgUmVzdE1ldGhvZCwgUmVzdFNlcnZpY2UgfSBmcm9tICcuLi8uLi9yZXN0JztcbmltcG9ydCB7IEJhbmtDb25uZWN0aW9uIH0gZnJvbSAnLi4vLi4vLi4vLi4vbW9kZWxzJztcbmltcG9ydCB7IElFdmVudExpc3RlbmVyIH0gZnJvbSAnLi4vLi4vLi4vLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBIdHRwRXJyb3JSZXNwb25zZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7IHRocm93RXJyb3IgYXMgb2JzZXJ2YWJsZVRocm93RXJyb3IgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IENvbGxlY3Rpb24gfSBmcm9tICcuLi8uLi8uLi8uLi9jb2xsZWN0aW9ucyc7XG5pbXBvcnQgeyBCYW5rQ29ubmVjdGlvbk1lc3NhZ2VzRW51bSB9IGZyb20gJy4vYmFuay1jb25uZWN0aW9uLW1lc3NhZ2VzLmVudW0nO1xuXG4vKipcbiAqIEJhbmtDb25uZWN0aW9uIG1lYW5zIHVzZXIgYWNjb3VudCBhdCBzcGVjaWZpYyBiYW5rICh1c3VhbGx5IGVhY2ggdXNlciBoYXMgb25seSBvbmUgYXQgdGhlIHNhbWUgYmFuaylcbiAqIHNlcnZpY2UgaGFuZGxlcyBCYW5rQ29ubmVjdGlvbiBtYW5hZ2VtZW50XG4gKi9cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIEJhbmtDb25uZWN0aW9uU2VydmljZSBleHRlbmRzIFJlc3RTZXJ2aWNlPEJhbmtDb25uZWN0aW9uQmFzZSwgQmFua0Nvbm5lY3Rpb24sIENvbGxlY3Rpb248QmFua0Nvbm5lY3Rpb24+PiBpbXBsZW1lbnRzIElFdmVudExpc3RlbmVyIHtcbiAgbW9kZWxDbGFzczogdHlwZW9mIEJhbmtDb25uZWN0aW9uID0gQmFua0Nvbm5lY3Rpb247XG4gIGNvbGxlY3Rpb25DbGFzczogdHlwZW9mIENvbGxlY3Rpb24gPSBDb2xsZWN0aW9uO1xuICBlbmRwb2ludFVyaSA9ICdiYW5rLWNvbm5lY3Rpb25zJztcbiAgZGlzYWJsZWRNZXRob2RzOiBSZXN0TWV0aG9kW10gPSBbJ3Bvc3RCYXRjaCcsICdwdXRCYXRjaCcsICdkZWxldGUnLCAnZGVsZXRlQmF0Y2gnXTtcbiAgbWVyY3VyZVRvcGljID0gJ2JhbmtDb25uZWN0aW9ucyc7XG5cbiAgY29uc3RydWN0b3IoQEluamVjdCgnZW52aXJvbm1lbnQnKSBwcm90ZWN0ZWQgZW52aXJvbm1lbnQ6IGFueSkge1xuICAgIHN1cGVyKGVudmlyb25tZW50KTtcbiAgICB0aGlzLmxpc3RlbkV2ZW50cygpO1xuICB9XG5cbiAgbGlzdGVuRXZlbnRzKCkge1xuICAgIC8vIEBUT0RPIHJlbW92ZSB3aGVuIFRULTM4MjYgaXMgcmVhZHlcbiAgICB0aGlzLmxpc3RlblNTRSgpO1xuICB9XG5cbiAgLyoqXG4gICAqIHRoZXJlIGlzIG5vIHB1dCBCYW5rQ29ubmVjdGlvbiBtZXRob2QsIHdlIGhhdmUgdG8gcG9zdCB0byB1cGRhdGVcbiAgICogUE9TVCBlbmRwb2ludCBpcyB1c2luZyBmb3IgY3JlYXRlIGFuZCBmb3IgdXBkYXRlLlxuICAgKi9cbiAgcG9zdChiYW5rQ29ubmVjdGlvbjogQmFua0Nvbm5lY3Rpb24pOiBPYnNlcnZhYmxlPEJhbmtDb25uZWN0aW9uPiB7XG4gICAgcmV0dXJuIHRoaXMuaHR0cC5wb3N0KHRoaXMuYXBpVXJsLCBiYW5rQ29ubmVjdGlvbilcbiAgICAgIC5waXBlKFxuICAgICAgICBtYXAoKHJlc3BvbnNlOiBCYW5rQ29ubmVjdGlvbkJhc2UpID0+IHtcbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBwbGFpblRvQ2xhc3MoQmFua0Nvbm5lY3Rpb24sIHJlc3BvbnNlKTtcblxuICAgICAgICAgIC8vIEBUT0RPIHRlc3QgaWYgYCFiYW5rQ29ubmVjdGlvbi5pZCAmJmAgZG9lc24ndCBicmVhayBhbnl0aGluZ1xuICAgICAgICAgIGlmIChyZXN1bHQuaXNCYXNpcSgpKSB7XG4gICAgICAgICAgICBzd2l0Y2ggKHRydWUpIHtcbiAgICAgICAgICAgICAgY2FzZSByZXN1bHQuaXNMb2dpblN1Y2Nlc3MoKTpcbiAgICAgICAgICAgICAgICB0aGlzLnRvYXN0U2VydmljZS5zdWNjZXNzKEJhbmtDb25uZWN0aW9uTWVzc2FnZXNFbnVtLkxPR0lOX1NVQ0NFU1MpO1xuICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgICAgICBjYXNlIHJlc3VsdC5pc0FjY291bnRzUmV0cmlldmVkKCk6XG4gICAgICAgICAgICAgICAgdGhpcy50b2FzdFNlcnZpY2Uuc3VjY2VzcyhCYW5rQ29ubmVjdGlvbk1lc3NhZ2VzRW51bS5BQ0NPVU5UU19SRVRSSUVWRUQpO1xuICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cblxuICAgICAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgICAgIH0pLFxuICAgICAgICBjYXRjaEVycm9yKChlcnJvcjogSHR0cEVycm9yUmVzcG9uc2UpID0+IHtcbiAgICAgICAgICAvLyBTaG93IGVycm9yIHdoZW4gdXNlciBwcm92aWRlZCB3cm9uZyBsb2dpbiBkYXRhXG4gICAgICAgICAgaWYgKGVycm9yLnN0YXR1cyA9PT0gNDAxKSB7XG4gICAgICAgICAgICB0aGlzLnRvYXN0U2VydmljZS5lcnJvcihCYW5rQ29ubmVjdGlvbk1lc3NhZ2VzRW51bS5JTlZBTElEX0NSRURFTlRJQUxTKTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICAvLyBTaG93IGVycm9yIHdoZW4gdXNlciBwcm92aWRlZCBhbm90aGVyIGxvZ2luIChub3QgbG9naW4gaGUgdXNlZCBiZWZvcmUpXG4gICAgICAgICAgaWYgKGVycm9yLnN0YXR1cyA9PT0gNDAwKSB7XG4gICAgICAgICAgICB0aGlzLnRvYXN0U2VydmljZS5lcnJvcihCYW5rQ29ubmVjdGlvbk1lc3NhZ2VzRW51bS5XUk9OR19MT0dJTl9EQVRBKTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBpZiAoZXJyb3Iuc3RhdHVzID09PSA1MDApIHtcbiAgICAgICAgICAgIHRoaXMudG9hc3RTZXJ2aWNlLmVycm9yKEJhbmtDb25uZWN0aW9uTWVzc2FnZXNFbnVtLlRFTVBPUkFSWV9VTkFWQUlMQUJMRSk7XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgcmV0dXJuIG9ic2VydmFibGVUaHJvd0Vycm9yKGVycm9yKTtcbiAgICAgICAgfSlcbiAgICAgIClcbiAgfVxuXG4gIGFjdGl2YXRlKGJhbmtDb25uZWN0aW9uOiBCYW5rQ29ubmVjdGlvbik6IE9ic2VydmFibGU8QmFua0Nvbm5lY3Rpb24+IHtcbiAgICByZXR1cm4gdGhpcy5wdXQoYmFua0Nvbm5lY3Rpb24sIGAke3RoaXMuYXBpVXJsfS8ke2JhbmtDb25uZWN0aW9uLmlkfS9hY3RpdmF0ZWApO1xuICB9XG5cbiAgZGVhY3RpdmF0ZShiYW5rQ29ubmVjdGlvbjogQmFua0Nvbm5lY3Rpb24pOiBPYnNlcnZhYmxlPEJhbmtDb25uZWN0aW9uPiB7XG4gICAgcmV0dXJuIHRoaXMucHV0KGJhbmtDb25uZWN0aW9uLCBgJHt0aGlzLmFwaVVybH0vJHtiYW5rQ29ubmVjdGlvbi5pZH0vZGVhY3RpdmF0ZWApO1xuICB9XG59XG4iXX0=
94
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bank-connection.service.js","sourceRoot":"","sources":["../../../../../../../../../projects/tt-core/src/lib/services/http/bank/bank-connection/bank-connection.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { catchError, map } from 'rxjs/operators';\nimport { BankConnection as BankConnectionBase } from '../../../../db/Models';\nimport { plainToClass } from 'class-transformer';\nimport { RestMethod, RestService } from '../../rest';\nimport { AppEventTypeEnum, BankConnection, Notification } from '../../../../models';\nimport { IEventListener } from '../../../../interfaces';\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { throwError as observableThrowError } from 'rxjs';\nimport { Collection } from '../../../../collections';\nimport { BankConnectionMessagesEnum } from './bank-connection-messages.enum';\nimport { UserEventTypeTypeEnum } from '../../../../db/Enums/user-event-type-type.enum';\n\n/**\n * BankConnection means user account at specific bank (usually each user has only one at the same bank)\n * service handles BankConnection management\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class BankConnectionService extends RestService<BankConnectionBase, BankConnection, Collection<BankConnection>> implements IEventListener {\n  modelClass: typeof BankConnection = BankConnection;\n  collectionClass: typeof Collection = Collection;\n  endpointUri = 'bank-connections';\n  disabledMethods: RestMethod[] = ['postBatch', 'putBatch', 'delete', 'deleteBatch'];\n\n  constructor(@Inject('environment') protected environment: any) {\n    super(environment);\n    this.listenEvents();\n  }\n\n  listenEvents() {\n    this.listenNotifications();\n  }\n\n  /**\n   * there is no put BankConnection method, we have to post to update\n   * POST endpoint is using for create and for update.\n   */\n  post(bankConnection: BankConnection): Observable<BankConnection> {\n    return this.http.post(this.apiUrl, bankConnection)\n      .pipe(\n        map((response: BankConnectionBase) => {\n          const result = plainToClass(BankConnection, response);\n\n          // @TODO test if `!bankConnection.id &&` doesn't break anything\n          if (result.isBasiq()) {\n            switch (true) {\n              case result.isLoginSuccess():\n                this.toastService.success(BankConnectionMessagesEnum.LOGIN_SUCCESS);\n                break;\n              case result.isAccountsRetrieved():\n                this.toastService.success(BankConnectionMessagesEnum.ACCOUNTS_RETRIEVED);\n                break;\n            }\n          }\n\n          return result;\n        }),\n        catchError((error: HttpErrorResponse) => {\n          // Show error when user provided wrong login data\n          if (error.status === 401) {\n            this.toastService.error(BankConnectionMessagesEnum.INVALID_CREDENTIALS);\n          }\n\n          // Show error when user provided another login (not login he used before)\n          if (error.status === 400) {\n            this.toastService.error(BankConnectionMessagesEnum.WRONG_LOGIN_DATA);\n          }\n\n          if (error.status === 500) {\n            this.toastService.error(BankConnectionMessagesEnum.TEMPORARY_UNAVAILABLE);\n          }\n\n          return observableThrowError(error);\n        })\n      )\n  }\n\n  activate(bankConnection: BankConnection): Observable<BankConnection> {\n    return this.put(bankConnection, `${this.apiUrl}/${bankConnection.id}/activate`);\n  }\n\n  deactivate(bankConnection: BankConnection): Observable<BankConnection> {\n    return this.put(bankConnection, `${this.apiUrl}/${bankConnection.id}/deactivate`);\n  }\n\n  private listenNotifications(): void {\n    this.eventDispatcherService.on(AppEventTypeEnum.NOTIFICATION_ADDED).subscribe((notification: Notification) => {\n      const events = [\n        UserEventTypeTypeEnum.BASIQ_NEW_ACCOUNTS,\n        UserEventTypeTypeEnum.BASIQ_FIRST_IMPORT_COMPLETE,\n        UserEventTypeTypeEnum.BASIQ_AUTHORIZATION_FAIL,\n      ];\n\n      if (!notification.isRead && events.includes(notification.eventType)) {\n        // @TODO TT-3826 move to unified mercure event\n        this.refreshCache();\n      }\n    });\n  }\n}\n"]}
@@ -7,7 +7,6 @@ import { RestService } from '../../rest';
7
7
  import { ClientMovement } from '../../../../models';
8
8
  import { AppEvent } from '../../../../models';
9
9
  import { AppEventTypeEnum } from '../../../../models';
10
- import { UserEventTypeTypeEnum } from '../../../../db/Enums/user-event-type-type.enum';
11
10
  import * as i0 from "@angular/core";
12
11
  export class ClientMovementService extends RestService {
13
12
  constructor(environment) {
@@ -17,6 +16,7 @@ export class ClientMovementService extends RestService {
17
16
  this.collectionClass = ClientMovementCollection;
18
17
  this.modelClass = ClientMovement;
19
18
  this.disabledMethods = ['postBatch', 'delete', 'deleteBatch'];
19
+ this.mercureTopic = 'clientMovements';
20
20
  this.listenEvents();
21
21
  }
22
22
  listenEvents() {
@@ -24,7 +24,8 @@ export class ClientMovementService extends RestService {
24
24
  this.eventDispatcherService.on([AppEventTypeEnum.CLIENT_INVITE_ACCEPTED]).subscribe(() => {
25
25
  this.refreshCache();
26
26
  });
27
- this.listenNotifications();
27
+ // @TODO remove when TT-3826 is ready
28
+ this.listenSSE();
28
29
  }
29
30
  getActive() {
30
31
  return this.get().pipe(map((clientMovements) => clientMovements.active));
@@ -72,21 +73,6 @@ export class ClientMovementService extends RestService {
72
73
  // this.updateCache([clientMovement], 'delete');
73
74
  }));
74
75
  }
75
- listenNotifications() {
76
- this.eventDispatcherService.on(AppEventTypeEnum.NOTIFICATION_ADDED).subscribe((notification) => {
77
- const events = [
78
- UserEventTypeTypeEnum.FIRM_INVITE_ACCEPTED,
79
- UserEventTypeTypeEnum.FIRM_INVITE_REJECTED,
80
- UserEventTypeTypeEnum.CLIENT_INVITE_ACCEPTED,
81
- UserEventTypeTypeEnum.CLIENT_INVITE_REJECTED,
82
- UserEventTypeTypeEnum.CLIENT_INVITE_REGISTERED,
83
- ];
84
- if (!notification.isRead && events.includes(notification.eventType)) {
85
- // @TODO TT-3826 move to unified mercure event
86
- this.refreshCache();
87
- }
88
- });
89
- }
90
76
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ClientMovementService, deps: [{ token: 'environment' }], target: i0.ɵɵFactoryTarget.Injectable }); }
91
77
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ClientMovementService, providedIn: 'root' }); }
92
78
  }
@@ -99,4 +85,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
99
85
  type: Inject,
100
86
  args: ['environment']
101
87
  }] }] });
102
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client-movement.service.js","sourceRoot":"","sources":["../../../../../../../../../projects/tt-core/src/lib/services/http/firm/client-movement/client-movement.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\nimport { ClientMovement as ClientMovementBase } from '../../../../db/Models/firm/client-movement';\nimport { Observable, forkJoin } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { ClientMovementCollection } from '../../../../collections';\nimport { FirmTypeEnum } from '../../../../db/Enums';\nimport { plainToClass } from 'class-transformer';\nimport { RestService } from '../../rest';\nimport { ClientMovement, Notification } from '../../../../models';\nimport { AppEvent } from '../../../../models';\nimport { AppEventTypeEnum } from '../../../../models';\nimport { IEventListener } from '../../../../interfaces';\nimport { RestMethod } from '../../rest';\nimport { UserEventTypeTypeEnum } from '../../../../db/Enums/user-event-type-type.enum';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ClientMovementService extends RestService<ClientMovementBase, ClientMovement, ClientMovementCollection> implements IEventListener {\n  protected endpointUri = 'client-movements';\n  collectionClass: typeof ClientMovementCollection = ClientMovementCollection;\n  modelClass: typeof ClientMovement = ClientMovement;\n  disabledMethods: RestMethod[] = ['postBatch', 'delete', 'deleteBatch'];\n\n  constructor(@Inject('environment') protected environment: any) {\n    super(environment);\n    this.listenEvents();\n  }\n\n  listenEvents(): void {\n    // client invite accept triggers client movement update\n    this.eventDispatcherService.on([AppEventTypeEnum.CLIENT_INVITE_ACCEPTED]).subscribe((): void => {\n      this.refreshCache();\n    });\n\n    this.listenNotifications();\n  }\n\n  getActive(): Observable<ClientMovementCollection> {\n    return this.get().pipe(\n      map((clientMovements: ClientMovementCollection): ClientMovementCollection => clientMovements.active)\n    );\n  }\n\n  getTTAdvisor(): Observable<ClientMovement> {\n    return this.getActive()\n      .pipe(\n        map((movements: ClientMovementCollection) => movements.findBy('employee.email', this.environment.ttAdvisor) || null)\n      );\n  }\n\n  getActiveByFirmType(type: FirmTypeEnum): Observable<ClientMovementCollection> {\n    return this.getActive().pipe(\n      map((clientMovements: ClientMovementCollection): ClientMovementCollection => clientMovements.getByFirmType(type))\n    );\n  }\n\n  /**\n   * @TODO use simple put when backend refactored (inner movements shouldn't create a new movement)\n   * Method is using for transfer client between employees.\n   * On backend we close passed movement and create a new one instead\n   */\n  put(movement: ClientMovement): Observable<ClientMovement> {\n    // extend base 'add' method and pass into it movement without id\n    return super.post(plainToClass(ClientMovement, Object.assign({}, movement, { id: null }))).pipe(\n      map((updatedMovement: ClientMovement) => {\n        // remove provided movement from cache\n        // this.cache = this.cache.filter((item: ClientMovement) => item.id !== movement.id);\n        this.updateCache([updatedMovement], 'post');\n\n        this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.CLIENT_TRANSFER_TO_OTHER_EMPLOYEE, [updatedMovement.client]));\n\n        return updatedMovement;\n      })\n    );\n  }\n\n  /**\n   * There is no actually direct updating of client movement, but we are using this method for transfer clients between employees\n   */\n  putBatch(clientMovements: ClientMovement[]): Observable<ClientMovement[]> {\n    const batch: Observable<ClientMovement>[] = clientMovements.map((clientMovement: ClientMovement) => this.put(clientMovement));\n\n    return forkJoin(batch);\n  }\n\n  /**\n   * Reject current firm\n   */\n  close(clientMovement: ClientMovement): Observable<void> {\n    // cant use parent method because of custom specific handler\n    return this.http.put(`${this.environment.apiV2}/client-movements/${clientMovement.id}/close`, {})\n      .pipe(\n        map((): void => {\n          // @TODO remove when TaxReviewService refactored with the new rest and use there listenCSE instead\n          this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.CLIENT_MOVEMENT_CLOSED, null));\n\n          // @TODO why commented?\n          // this.cache = this.cache.filter((movement: ClientMovement): boolean => movement.id !== clientMovement.id);\n          // this.updateCache([clientMovement], 'delete');\n        })\n      );\n  }\n\n  private listenNotifications(): void {\n    this.eventDispatcherService.on(AppEventTypeEnum.NOTIFICATION_ADDED).subscribe((notification: Notification) => {\n      const events = [\n        UserEventTypeTypeEnum.FIRM_INVITE_ACCEPTED,\n        UserEventTypeTypeEnum.FIRM_INVITE_REJECTED,\n        UserEventTypeTypeEnum.CLIENT_INVITE_ACCEPTED,\n        UserEventTypeTypeEnum.CLIENT_INVITE_REJECTED,\n        UserEventTypeTypeEnum.CLIENT_INVITE_REGISTERED,\n      ];\n\n      if (!notification.isRead && events.includes(notification.eventType)) {\n        // @TODO TT-3826 move to unified mercure event\n        this.refreshCache();\n      }\n    });\n  }\n}\n"]}
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client-movement.service.js","sourceRoot":"","sources":["../../../../../../../../../projects/tt-core/src/lib/services/http/firm/client-movement/client-movement.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAEnD,OAAO,EAAc,QAAQ,EAAE,MAAM,MAAM,CAAC;AAC5C,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,wBAAwB,EAAE,MAAM,yBAAyB,CAAC;AAEnE,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;;AAOtD,MAAM,OAAO,qBAAsB,SAAQ,WAAyE;IAOlH,YAA6C,WAAgB;QAC3D,KAAK,CAAC,WAAW,CAAC,CAAC;QADwB,gBAAW,GAAX,WAAW,CAAK;QANnD,gBAAW,GAAG,kBAAkB,CAAC;QAC3C,oBAAe,GAAoC,wBAAwB,CAAC;QAC5E,eAAU,GAA0B,cAAc,CAAC;QACnD,oBAAe,GAAiB,CAAC,WAAW,EAAE,QAAQ,EAAE,aAAa,CAAC,CAAC;QACvE,iBAAY,GAAG,iBAAiB,CAAC;QAI/B,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,YAAY;QACV,uDAAuD;QACvD,IAAI,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC,gBAAgB,CAAC,sBAAsB,CAAC,CAAC,CAAC,SAAS,CAAC,GAAS,EAAE;YAC7F,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC,CAAC,CAAC;QACH,qCAAqC;QACrC,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CACpB,GAAG,CAAC,CAAC,eAAyC,EAA4B,EAAE,CAAC,eAAe,CAAC,MAAM,CAAC,CACrG,CAAC;IACJ,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,SAAS,EAAE;aACpB,IAAI,CACH,GAAG,CAAC,CAAC,SAAmC,EAAE,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,gBAAgB,EAAE,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC,CACrH,CAAC;IACN,CAAC;IAED,mBAAmB,CAAC,IAAkB;QACpC,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC,IAAI,CAC1B,GAAG,CAAC,CAAC,eAAyC,EAA4B,EAAE,CAAC,eAAe,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAClH,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACH,GAAG,CAAC,QAAwB;QAC1B,gEAAgE;QAChE,OAAO,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAC7F,GAAG,CAAC,CAAC,eAA+B,EAAE,EAAE;YACtC,sCAAsC;YACtC,qFAAqF;YACrF,IAAI,CAAC,WAAW,CAAC,CAAC,eAAe,CAAC,EAAE,MAAM,CAAC,CAAC;YAE5C,IAAI,CAAC,sBAAsB,CAAC,QAAQ,CAAC,IAAI,QAAQ,CAAC,gBAAgB,CAAC,iCAAiC,EAAE,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YAEjI,OAAO,eAAe,CAAC;QACzB,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,QAAQ,CAAC,eAAiC;QACxC,MAAM,KAAK,GAAiC,eAAe,CAAC,GAAG,CAAC,CAAC,cAA8B,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC;QAE9H,OAAO,QAAQ,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,cAA8B;QAClC,4DAA4D;QAC5D,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,qBAAqB,cAAc,CAAC,EAAE,QAAQ,EAAE,EAAE,CAAC;aAC9F,IAAI,CACH,GAAG,CAAC,GAAS,EAAE;YACb,kGAAkG;YAClG,IAAI,CAAC,sBAAsB,CAAC,QAAQ,CAAC,IAAI,QAAQ,CAAC,gBAAgB,CAAC,sBAAsB,EAAE,IAAI,CAAC,CAAC,CAAC;YAElG,uBAAuB;YACvB,4GAA4G;YAC5G,gDAAgD;QAClD,CAAC,CAAC,CACH,CAAC;IACN,CAAC;+GArFU,qBAAqB,kBAOZ,aAAa;mHAPtB,qBAAqB,cAFpB,MAAM;;4FAEP,qBAAqB;kBAHjC,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB;;0BAQc,MAAM;2BAAC,aAAa","sourcesContent":["import { Inject, Injectable } from '@angular/core';\nimport { ClientMovement as ClientMovementBase } from '../../../../db/Models/firm/client-movement';\nimport { Observable, forkJoin } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { ClientMovementCollection } from '../../../../collections';\nimport { FirmTypeEnum } from '../../../../db/Enums';\nimport { plainToClass } from 'class-transformer';\nimport { RestService } from '../../rest';\nimport { ClientMovement } from '../../../../models';\nimport { AppEvent } from '../../../../models';\nimport { AppEventTypeEnum } from '../../../../models';\nimport { IEventListener } from '../../../../interfaces';\nimport { RestMethod } from '../../rest';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ClientMovementService extends RestService<ClientMovementBase, ClientMovement, ClientMovementCollection> implements IEventListener {\n  protected endpointUri = 'client-movements';\n  collectionClass: typeof ClientMovementCollection = ClientMovementCollection;\n  modelClass: typeof ClientMovement = ClientMovement;\n  disabledMethods: RestMethod[] = ['postBatch', 'delete', 'deleteBatch'];\n  mercureTopic = 'clientMovements';\n\n  constructor(@Inject('environment') protected environment: any) {\n    super(environment);\n    this.listenEvents();\n  }\n\n  listenEvents(): void {\n    // client invite accept triggers client movement update\n    this.eventDispatcherService.on([AppEventTypeEnum.CLIENT_INVITE_ACCEPTED]).subscribe((): void => {\n      this.refreshCache();\n    });\n    // @TODO remove when TT-3826 is ready\n    this.listenSSE();\n  }\n\n  getActive(): Observable<ClientMovementCollection> {\n    return this.get().pipe(\n      map((clientMovements: ClientMovementCollection): ClientMovementCollection => clientMovements.active)\n    );\n  }\n\n  getTTAdvisor(): Observable<ClientMovement> {\n    return this.getActive()\n      .pipe(\n        map((movements: ClientMovementCollection) => movements.findBy('employee.email', this.environment.ttAdvisor) || null)\n      );\n  }\n\n  getActiveByFirmType(type: FirmTypeEnum): Observable<ClientMovementCollection> {\n    return this.getActive().pipe(\n      map((clientMovements: ClientMovementCollection): ClientMovementCollection => clientMovements.getByFirmType(type))\n    );\n  }\n\n  /**\n   * @TODO use simple put when backend refactored (inner movements shouldn't create a new movement)\n   * Method is using for transfer client between employees.\n   * On backend we close passed movement and create a new one instead\n   */\n  put(movement: ClientMovement): Observable<ClientMovement> {\n    // extend base 'add' method and pass into it movement without id\n    return super.post(plainToClass(ClientMovement, Object.assign({}, movement, { id: null }))).pipe(\n      map((updatedMovement: ClientMovement) => {\n        // remove provided movement from cache\n        // this.cache = this.cache.filter((item: ClientMovement) => item.id !== movement.id);\n        this.updateCache([updatedMovement], 'post');\n\n        this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.CLIENT_TRANSFER_TO_OTHER_EMPLOYEE, [updatedMovement.client]));\n\n        return updatedMovement;\n      })\n    );\n  }\n\n  /**\n   * There is no actually direct updating of client movement, but we are using this method for transfer clients between employees\n   */\n  putBatch(clientMovements: ClientMovement[]): Observable<ClientMovement[]> {\n    const batch: Observable<ClientMovement>[] = clientMovements.map((clientMovement: ClientMovement) => this.put(clientMovement));\n\n    return forkJoin(batch);\n  }\n\n  /**\n   * Reject current firm\n   */\n  close(clientMovement: ClientMovement): Observable<void> {\n    // cant use parent method because of custom specific handler\n    return this.http.put(`${this.environment.apiV2}/client-movements/${clientMovement.id}/close`, {})\n      .pipe(\n        map((): void => {\n          // @TODO remove when TaxReviewService refactored with the new rest and use there listenCSE instead\n          this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.CLIENT_MOVEMENT_CLOSED, null));\n\n          // @TODO why commented?\n          // this.cache = this.cache.filter((movement: ClientMovement): boolean => movement.id !== clientMovement.id);\n          // this.updateCache([clientMovement], 'delete');\n        })\n      );\n  }\n}\n"]}
@@ -13,15 +13,15 @@ export class HoldingTypeService extends RestService {
13
13
  this.endpointUri = 'holding-types';
14
14
  this.disabledMethods = ['postBatch', 'putBatch', 'deleteBatch'];
15
15
  this.roles = [UserRolesEnum.HOLDING_TANK];
16
- // this.listenEvents();
16
+ this.listenEvents();
17
+ }
18
+ search(query, category = null) {
19
+ query = query.toLowerCase().trim();
20
+ return this.fetch(`${this.apiUrl}`, false, { params: { query, category } });
21
+ }
22
+ getCurrent() {
23
+ return this.get(`${this.apiUrl}/current`);
17
24
  }
18
- // search(searchQuery: string, category: HoldingTypeCategoryEnum = null): Observable<HoldingType[]> {
19
- // searchQuery = searchQuery.toLowerCase().trim();
20
- //
21
- // return this.http.get(`${this.apiUrl}`, { params: { searchQuery, category } }).pipe(
22
- // map((userBase: UserBase) => this.createModelInstance(userBase))
23
- // );
24
- // }
25
25
  listenEvents() {
26
26
  this.listenCSE(BankTransaction, (trade) => this.hasInCache(trade.holdingType.id) ? this.updateCache([trade.holdingType], 'post') : '', ['post']);
27
27
  }
@@ -37,4 +37,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
37
37
  type: Inject,
38
38
  args: ['environment']
39
39
  }] }] });
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaG9sZGluZy10eXBlLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dC1jb3JlL3NyYy9saWIvc2VydmljZXMvaHR0cC9ob2xkaW5nL2hvbGRpbmctdHlwZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRW5ELE9BQU8sRUFBRSxlQUFlLEVBQWdCLFdBQVcsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzdFLE9BQU8sRUFBYyxXQUFXLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDbEQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFN0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQVFwRCxNQUFNLE9BQU8sa0JBQW1CLFNBQVEsV0FBZ0U7SUFPdEcsWUFBNkMsV0FBZ0I7UUFDM0QsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBRHdCLGdCQUFXLEdBQVgsV0FBVyxDQUFLO1FBTjdELGVBQVUsR0FBdUIsV0FBVyxDQUFDO1FBQzdDLG9CQUFlLEdBQWlDLHFCQUFxQixDQUFDO1FBQ3RFLGdCQUFXLEdBQUcsZUFBZSxDQUFDO1FBQzlCLG9CQUFlLEdBQWlCLENBQUMsV0FBVyxFQUFFLFVBQVUsRUFBRSxhQUFhLENBQUMsQ0FBQztRQUN6RSxVQUFLLEdBQUcsQ0FBQyxhQUFhLENBQUMsWUFBWSxDQUFDLENBQUM7UUFJbkMsdUJBQXVCO0lBQ3pCLENBQUM7SUFFRCxxR0FBcUc7SUFDckcsb0RBQW9EO0lBQ3BELEVBQUU7SUFDRix3RkFBd0Y7SUFDeEYsc0VBQXNFO0lBQ3RFLE9BQU87SUFDUCxJQUFJO0lBRUosWUFBWTtRQUNWLElBQUksQ0FBQyxTQUFTLENBQ1osZUFBZSxFQUNmLENBQUMsS0FBbUIsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQ25ILENBQUMsTUFBTSxDQUFDLENBQ1QsQ0FBQztJQUNKLENBQUM7K0dBMUJVLGtCQUFrQixrQkFPVCxhQUFhO21IQVB0QixrQkFBa0IsY0FGakIsTUFBTTs7NEZBRVAsa0JBQWtCO2tCQUg5QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQjs7MEJBUWMsTUFBTTsyQkFBQyxhQUFhIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0LCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBIb2xkaW5nVHlwZSBhcyBIb2xkaW5nVHlwZUJhc2UgfSBmcm9tICcuLi8uLi8uLi9kYi9Nb2RlbHMnO1xuaW1wb3J0IHsgQmFua1RyYW5zYWN0aW9uLCBIb2xkaW5nVHJhZGUsIEhvbGRpbmdUeXBlIH0gZnJvbSAnLi4vLi4vLi4vbW9kZWxzJztcbmltcG9ydCB7IFJlc3RNZXRob2QsIFJlc3RTZXJ2aWNlIH0gZnJvbSAnLi4vcmVzdCc7XG5pbXBvcnQgeyBIb2xkaW5nVHlwZUNvbGxlY3Rpb24gfSBmcm9tICcuLi8uLi8uLi9jb2xsZWN0aW9ucyc7XG5pbXBvcnQgeyBJRXZlbnRMaXN0ZW5lciB9IGZyb20gJy4uLy4uLy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgVXNlclJvbGVzRW51bSB9IGZyb20gJ3RheHRhbmstY29yZS9jb21tb24nO1xuaW1wb3J0IHsgSG9sZGluZ1R5cGVDYXRlZ29yeUVudW0gfSBmcm9tICcuLi8uLi8uLi9kYi9FbnVtcyc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBtYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIEhvbGRpbmdUeXBlU2VydmljZSBleHRlbmRzIFJlc3RTZXJ2aWNlPEhvbGRpbmdUeXBlQmFzZSwgSG9sZGluZ1R5cGUsIEhvbGRpbmdUeXBlQ29sbGVjdGlvbj4gaW1wbGVtZW50cyBJRXZlbnRMaXN0ZW5lciB7XG4gIG1vZGVsQ2xhc3M6IHR5cGVvZiBIb2xkaW5nVHlwZSA9IEhvbGRpbmdUeXBlO1xuICBjb2xsZWN0aW9uQ2xhc3M6IHR5cGVvZiBIb2xkaW5nVHlwZUNvbGxlY3Rpb24gPSBIb2xkaW5nVHlwZUNvbGxlY3Rpb247XG4gIGVuZHBvaW50VXJpID0gJ2hvbGRpbmctdHlwZXMnO1xuICBkaXNhYmxlZE1ldGhvZHM6IFJlc3RNZXRob2RbXSA9IFsncG9zdEJhdGNoJywgJ3B1dEJhdGNoJywgJ2RlbGV0ZUJhdGNoJ107XG4gIHJvbGVzID0gW1VzZXJSb2xlc0VudW0uSE9MRElOR19UQU5LXTtcblxuICBjb25zdHJ1Y3RvcihASW5qZWN0KCdlbnZpcm9ubWVudCcpIHByb3RlY3RlZCBlbnZpcm9ubWVudDogYW55KSB7XG4gICAgc3VwZXIoZW52aXJvbm1lbnQpO1xuICAgIC8vIHRoaXMubGlzdGVuRXZlbnRzKCk7XG4gIH1cblxuICAvLyBzZWFyY2goc2VhcmNoUXVlcnk6IHN0cmluZywgY2F0ZWdvcnk6IEhvbGRpbmdUeXBlQ2F0ZWdvcnlFbnVtID0gbnVsbCk6IE9ic2VydmFibGU8SG9sZGluZ1R5cGVbXT4ge1xuICAvLyAgIHNlYXJjaFF1ZXJ5ID0gc2VhcmNoUXVlcnkudG9Mb3dlckNhc2UoKS50cmltKCk7XG4gIC8vXG4gIC8vICAgcmV0dXJuIHRoaXMuaHR0cC5nZXQoYCR7dGhpcy5hcGlVcmx9YCwgeyBwYXJhbXM6IHsgc2VhcmNoUXVlcnksIGNhdGVnb3J5IH0gfSkucGlwZShcbiAgLy8gICAgIG1hcCgodXNlckJhc2U6IFVzZXJCYXNlKSA9PiB0aGlzLmNyZWF0ZU1vZGVsSW5zdGFuY2UodXNlckJhc2UpKVxuICAvLyAgICk7XG4gIC8vIH1cblxuICBsaXN0ZW5FdmVudHMoKTogdm9pZCB7XG4gICAgdGhpcy5saXN0ZW5DU0UoXG4gICAgICBCYW5rVHJhbnNhY3Rpb24sXG4gICAgICAodHJhZGU6IEhvbGRpbmdUcmFkZSkgPT4gdGhpcy5oYXNJbkNhY2hlKHRyYWRlLmhvbGRpbmdUeXBlLmlkKSA/IHRoaXMudXBkYXRlQ2FjaGUoW3RyYWRlLmhvbGRpbmdUeXBlXSwgJ3Bvc3QnKSA6ICcnLFxuICAgICAgWydwb3N0J11cbiAgICApO1xuICB9XG59XG4iXX0=
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaG9sZGluZy10eXBlLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dC1jb3JlL3NyYy9saWIvc2VydmljZXMvaHR0cC9ob2xkaW5nL2hvbGRpbmctdHlwZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRW5ELE9BQU8sRUFBRSxlQUFlLEVBQWdCLFdBQVcsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzdFLE9BQU8sRUFBYyxXQUFXLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDbEQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFN0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQVFwRCxNQUFNLE9BQU8sa0JBQW1CLFNBQVEsV0FBZ0U7SUFPdEcsWUFBNkMsV0FBZ0I7UUFDM0QsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBRHdCLGdCQUFXLEdBQVgsV0FBVyxDQUFLO1FBTjdELGVBQVUsR0FBdUIsV0FBVyxDQUFDO1FBQzdDLG9CQUFlLEdBQWlDLHFCQUFxQixDQUFDO1FBQ3RFLGdCQUFXLEdBQUcsZUFBZSxDQUFDO1FBQzlCLG9CQUFlLEdBQWlCLENBQUMsV0FBVyxFQUFFLFVBQVUsRUFBRSxhQUFhLENBQUMsQ0FBQztRQUN6RSxVQUFLLEdBQUcsQ0FBQyxhQUFhLENBQUMsWUFBWSxDQUFDLENBQUM7UUFJbkMsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3RCLENBQUM7SUFFRCxNQUFNLENBQUMsS0FBYSxFQUFFLFdBQW9DLElBQUk7UUFDNUQsS0FBSyxHQUFHLEtBQUssQ0FBQyxXQUFXLEVBQUUsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUVuQyxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsS0FBSyxFQUFFLEVBQUUsTUFBTSxFQUFFLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUM5RSxDQUFDO0lBRUQsVUFBVTtRQUNSLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNLFVBQVUsQ0FBQyxDQUFDO0lBQzVDLENBQUM7SUFFRCxZQUFZO1FBQ1YsSUFBSSxDQUFDLFNBQVMsQ0FDWixlQUFlLEVBQ2YsQ0FBQyxLQUFtQixFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFDbkgsQ0FBQyxNQUFNLENBQUMsQ0FDVCxDQUFDO0lBQ0osQ0FBQzsrR0E1QlUsa0JBQWtCLGtCQU9ULGFBQWE7bUhBUHRCLGtCQUFrQixjQUZqQixNQUFNOzs0RkFFUCxrQkFBa0I7a0JBSDlCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25COzswQkFRYyxNQUFNOzJCQUFDLGFBQWEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3QsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEhvbGRpbmdUeXBlIGFzIEhvbGRpbmdUeXBlQmFzZSB9IGZyb20gJy4uLy4uLy4uL2RiL01vZGVscyc7XG5pbXBvcnQgeyBCYW5rVHJhbnNhY3Rpb24sIEhvbGRpbmdUcmFkZSwgSG9sZGluZ1R5cGUgfSBmcm9tICcuLi8uLi8uLi9tb2RlbHMnO1xuaW1wb3J0IHsgUmVzdE1ldGhvZCwgUmVzdFNlcnZpY2UgfSBmcm9tICcuLi9yZXN0JztcbmltcG9ydCB7IEhvbGRpbmdUeXBlQ29sbGVjdGlvbiB9IGZyb20gJy4uLy4uLy4uL2NvbGxlY3Rpb25zJztcbmltcG9ydCB7IElFdmVudExpc3RlbmVyIH0gZnJvbSAnLi4vLi4vLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBVc2VyUm9sZXNFbnVtIH0gZnJvbSAndGF4dGFuay1jb3JlL2NvbW1vbic7XG5pbXBvcnQgeyBIb2xkaW5nVHlwZUNhdGVnb3J5RW51bSB9IGZyb20gJy4uLy4uLy4uL2RiL0VudW1zJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IG1hcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgSG9sZGluZ1R5cGVTZXJ2aWNlIGV4dGVuZHMgUmVzdFNlcnZpY2U8SG9sZGluZ1R5cGVCYXNlLCBIb2xkaW5nVHlwZSwgSG9sZGluZ1R5cGVDb2xsZWN0aW9uPiBpbXBsZW1lbnRzIElFdmVudExpc3RlbmVyIHtcbiAgbW9kZWxDbGFzczogdHlwZW9mIEhvbGRpbmdUeXBlID0gSG9sZGluZ1R5cGU7XG4gIGNvbGxlY3Rpb25DbGFzczogdHlwZW9mIEhvbGRpbmdUeXBlQ29sbGVjdGlvbiA9IEhvbGRpbmdUeXBlQ29sbGVjdGlvbjtcbiAgZW5kcG9pbnRVcmkgPSAnaG9sZGluZy10eXBlcyc7XG4gIGRpc2FibGVkTWV0aG9kczogUmVzdE1ldGhvZFtdID0gWydwb3N0QmF0Y2gnLCAncHV0QmF0Y2gnLCAnZGVsZXRlQmF0Y2gnXTtcbiAgcm9sZXMgPSBbVXNlclJvbGVzRW51bS5IT0xESU5HX1RBTktdO1xuXG4gIGNvbnN0cnVjdG9yKEBJbmplY3QoJ2Vudmlyb25tZW50JykgcHJvdGVjdGVkIGVudmlyb25tZW50OiBhbnkpIHtcbiAgICBzdXBlcihlbnZpcm9ubWVudCk7XG4gICAgdGhpcy5saXN0ZW5FdmVudHMoKTtcbiAgfVxuXG4gIHNlYXJjaChxdWVyeTogc3RyaW5nLCBjYXRlZ29yeTogSG9sZGluZ1R5cGVDYXRlZ29yeUVudW0gPSBudWxsKTogT2JzZXJ2YWJsZTxIb2xkaW5nVHlwZUNvbGxlY3Rpb24+IHtcbiAgICBxdWVyeSA9IHF1ZXJ5LnRvTG93ZXJDYXNlKCkudHJpbSgpO1xuXG4gICAgcmV0dXJuIHRoaXMuZmV0Y2goYCR7dGhpcy5hcGlVcmx9YCwgZmFsc2UsIHsgcGFyYW1zOiB7IHF1ZXJ5LCBjYXRlZ29yeSB9IH0pO1xuICB9XG5cbiAgZ2V0Q3VycmVudCgpOiBPYnNlcnZhYmxlPEhvbGRpbmdUeXBlQ29sbGVjdGlvbj4ge1xuICAgIHJldHVybiB0aGlzLmdldChgJHt0aGlzLmFwaVVybH0vY3VycmVudGApO1xuICB9XG5cbiAgbGlzdGVuRXZlbnRzKCk6IHZvaWQge1xuICAgIHRoaXMubGlzdGVuQ1NFKFxuICAgICAgQmFua1RyYW5zYWN0aW9uLFxuICAgICAgKHRyYWRlOiBIb2xkaW5nVHJhZGUpID0+IHRoaXMuaGFzSW5DYWNoZSh0cmFkZS5ob2xkaW5nVHlwZS5pZCkgPyB0aGlzLnVwZGF0ZUNhY2hlKFt0cmFkZS5ob2xkaW5nVHlwZV0sICdwb3N0JykgOiAnJyxcbiAgICAgIFsncG9zdCddXG4gICAgKTtcbiAgfVxufVxuIl19
@@ -79,13 +79,17 @@ export class RestService extends DataService {
79
79
  /**
80
80
  * Get data from backend and fill the cache
81
81
  */
82
- fetch(path = this.apiUrl, cache = true) {
83
- // Set cache as empty collection to avoid multiple requests before cache filled
84
- this.setCache([]);
85
- return this.http.get(path)
82
+ fetch(path = this.apiUrl, cache = true, queryParams = {}) {
83
+ if (cache) {
84
+ // Set cache as empty collection to avoid multiple requests before cache filled
85
+ this.setCache([]);
86
+ }
87
+ return this.http.get(path, queryParams)
86
88
  .pipe(map((response) => Array.isArray(response) ? response : toArray(response)), map((response) => {
87
- this.setCache(response, true);
88
- return this.cache;
89
+ if (cache) {
90
+ this.setCache(response, true);
91
+ }
92
+ return this.createCollectionInstance(this.collectionClass, response);
89
93
  }), catchError((error) => this.handleError(error)));
90
94
  }
91
95
  get(path = this.apiUrl) {
@@ -246,8 +250,8 @@ export class RestService extends DataService {
246
250
  case 'delete':
247
251
  cache = this.cache.removeBy('id', items.map((item) => item.id));
248
252
  break;
249
- case 'get':
250
- cache = this.createCollectionInstance(this.collectionClass, items);
253
+ // case 'get':
254
+ // cache = this.createCollectionInstance(this.collectionClass, items);
251
255
  }
252
256
  this.setCache(cache.toArray(), true);
253
257
  }
@@ -327,4 +331,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
327
331
  type: Inject,
328
332
  args: ['environment']
329
333
  }] }] });
330
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rest.service.js","sourceRoot":"","sources":["../../../../../../../../projects/tt-core/src/lib/services/http/rest/rest.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, inject } from '@angular/core';\nimport { Observable, ReplaySubject, of, throwError } from 'rxjs';\nimport { catchError, first, map } from 'rxjs/operators';\nimport { HttpClient, HttpErrorResponse } from '@angular/common/http';\nimport { EventDispatcherService, SseService } from '../../event';\nimport { classToPlain } from 'class-transformer';\nimport { Collection } from '../../../collections';\nimport { AbstractModel, ObservableModel } from '../../../db/Models';\nimport { AppEvent2 } from '../../../models';\nimport { toArray } from '../../../functions/array';\nimport { RestMethod } from './rest-method.type';\nimport { HttpMethod } from './http-method.type';\nimport { DataService } from '../../data.service';\nimport { UserRolesEnum } from 'taxtank-core/common';\nimport { ToastService } from '../../toast';\nimport merge from 'lodash/merge';\nimport intersection from 'lodash/intersection';\nimport last from 'lodash/last';\nimport cloneDeep from 'lodash/cloneDeep';\nimport { HTTP_ERROR_MESSAGES } from './http-error-messages.const';\n\n/**\n * @TODO refactor to behavior subject?\n * Abstract base service that implements common services functionality\n * and describe abstract methods/properties that have to be implemented in child services\n * Model - entity service is working with\n * BaseModel - base entity model that extends by Model\n * CollectionModel - entity collection class\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport abstract class RestService<BaseModel, Model extends AbstractModel, CollectionModel extends Collection<Model>>\n  extends DataService<BaseModel, Model, CollectionModel> {\n\n  /**\n   * Url part for service entity API\n   */\n  protected abstract endpointUri: string;\n\n  /**\n   * Subject for service cache\n   */\n  protected cacheSubject: ReplaySubject<CollectionModel> = new ReplaySubject(1);\n\n  /**\n   * List of methods unavailable for current API\n   * @TODO Alex: add and handle enabled methods too\n   * @TODO Alex: disable batch by default\n   */\n  disabledMethods: RestMethod[] = [];\n  protected sseService: SseService = inject(SseService);\n  protected toastService: ToastService = inject(ToastService);\n  protected http: HttpClient = inject(HttpClient);\n  protected eventDispatcherService: EventDispatcherService = inject(EventDispatcherService);\n  /**\n   * adds new entities to the beginning when true\n   * @TODO make true by default when all services refactored\n   */\n  protected orderByDesc = false;\n\n  roles: UserRolesEnum[] = [];\n  mercureTopic: string;\n  /**\n   * flag to use error messages from api or default ones\n   * @TODO: TT-4642 check customHttpErrorMessages fix change to backend errors\n   */\n  protected useBackendError = false;\n\n  /**\n   * mapping with HTTP errors codes and general messages\n   */\n  protected httpErrorMessages: {[key: number]: string};\n\n  constructor(@Inject('environment') protected environment: any) {\n    super();\n    this.httpErrorMessages = { ...HTTP_ERROR_MESSAGES, ...this.getCustomHttpErrorMessages() };\n  }\n\n  protected get apiUrl(): string {\n    return `${this.environment.apiV2}/${this.endpointUri}`;\n  }\n\n  setCache(data: any[], next = false): void {\n    super.setCache(data);\n\n    if (next) {\n      this.cacheSubject.next(this.cache);\n    }\n  }\n\n  /**\n   * Refresh cache with actual backend data\n   */\n  refreshCache(): void {\n    this.cache = undefined;\n    this.get();\n  }\n\n  /**\n   * perform a shallow copy of the emitted data to make it immutable\n   */\n  getCacheSubjectObservable(): Observable<CollectionModel> {\n    return this.cacheSubject.asObservable().pipe(map((cache) => cloneDeep(cache)));\n  }\n\n  /**\n   * Get data from backend and fill the cache\n   */\n  fetch(path = this.apiUrl, cache = true): Observable<CollectionModel> {\n    // Set cache as empty collection to avoid multiple requests before cache filled\n    this.setCache([]);\n    return this.http.get(path)\n      .pipe(\n        map((response: object | object[]) => Array.isArray(response) ? response : toArray(response)),\n        map((response: BaseModel[]) => {\n          this.setCache(response, true);\n\n          return this.cache;\n        }),\n        catchError((error: unknown) => this.handleError(error))\n      );\n  }\n\n  get(path: string = this.apiUrl): Observable<CollectionModel> {\n    this.handleAccessError('get');\n\n    if (!this.hasRoles()) {\n      return of(this.createCollectionInstance(this.collectionClass, []));\n    }\n\n    if (!this.cache) {\n      this.fetch(path).pipe(first()).subscribe();\n    }\n\n    return this.getCacheSubjectObservable();\n  }\n\n  getBy(path: string, values: any): Observable<CollectionModel> {\n    return this.get().pipe(map((projects) => projects.filterBy(path, values)));\n  }\n\n  getFirst(): Observable<Model> {\n    return this.get().pipe(map((collection: CollectionModel) => collection.first));\n  }\n\n  hasInCache(id: number): boolean {\n    return !!this.getCache()?.findBy('id', id);\n  }\n\n  getArray(): Observable<Model[]> {\n    return this.get().pipe(map((collection: CollectionModel) => collection.toArray()));\n  }\n\n  getArrayBy(path: string, values: any): Observable<Model[]> {\n    return this.getBy(path, values).pipe(map((collection: CollectionModel) => collection.toArray()));\n  }\n\n  /**\n   * Create a new Model instance in database\n   */\n  post(model: Model, path: string = this.apiUrl): Observable<Model> {\n    this.handleAccessError('post');\n\n    return this.http.post(path, classToPlain(model))\n      .pipe(\n        map((response: object) => {\n          const result: Model = this.createModelInstance(response);\n          if (!this.mercureTopic) {\n            this.handleResponse([result], 'post');\n          }\n\n          return result;\n        }),\n        catchError((error: unknown) => this.handleError(error))\n      );\n  }\n\n  /**\n   * Create multiple new Model instances in database\n   */\n  postBatch(models: Model[]): Observable<Model[]> {\n    this.handleAccessError('postBatch');\n\n    return this.http.post(this.apiUrl, classToPlain(models))\n      .pipe(\n        map((response: object[]) => {\n          const result: Model[] = response.map((item: object): Model => this.createModelInstance(item));\n          if (!this.mercureTopic) {\n            this.handleResponse(result, 'post');\n          }\n\n          return result;\n        }),\n        catchError((error: unknown) => this.handleError(error))\n      );\n  }\n\n  /**\n   * Change an existing Model instance in database\n   */\n  put(model: Model, path = `${this.apiUrl}/${model.id}`): Observable<Model> {\n    this.handleAccessError('put');\n\n    return this.http.put(path, classToPlain(model))\n      .pipe(\n        map((response: object) => {\n          const result: Model = this.createModelInstance(response);\n          if (!this.mercureTopic) {\n            this.handleResponse([result], 'put');\n          }\n\n          return result;\n        }),\n        catchError((error: unknown) => this.handleError(error))\n      );\n  }\n\n  /**\n   * Change multiple existing Model instances in database\n   */\n  putBatch(models: Model[]): Observable<Model[]> {\n    this.handleAccessError('putBatch');\n\n    return this.http.put(this.apiUrl, classToPlain(models))\n      .pipe(\n        map((response: object[]) => {\n          const result: Model[] = response.map((item: object): Model => this.createModelInstance(item));\n          if (!this.mercureTopic) {\n            this.handleResponse(result, 'put');\n          }\n\n          return result;\n        })\n      );\n  }\n\n  /**\n   * Remove a Model instance from database\n   */\n  delete(model: Model, path = `${this.apiUrl}/${model.id}`): Observable<void> {\n    this.handleAccessError('delete');\n\n    return this.http.delete(path)\n      .pipe(\n        map(() => {\n          if (!this.mercureTopic) {\n            this.handleResponse([model], 'delete');\n          }\n        }),\n        catchError((error: unknown) => this.handleError(error))\n      );\n  }\n\n  /**\n   * Remove multiple Model instances from database\n   */\n  deleteBatch(models: Model[]): Observable<void> {\n    this.handleAccessError('deleteBatch');\n\n    return this.http.post(`${this.apiUrl}/delete`, classToPlain(models))\n      .pipe(\n        map(() => {\n          if (!this.mercureTopic) {\n            this.handleResponse(models, 'delete');\n          }\n        }),\n        catchError((error: unknown) => this.handleError(error))\n      );\n  }\n\n  /**\n   * method with messages that can be redefined in other classes to customize httpErrorMessages\n   */\n  protected getCustomHttpErrorMessages(): Record<number, string> {\n    return {}\n  }\n  /**\n   * Handle response errors - shows error in toast\n   * and throws error further\n   * @param error - any backend error\n   * @throws HttpErrorResponse | Error - Always throws the error further as an Observable<never>\n   */\n  handleError(error: unknown) {\n    if (error instanceof HttpErrorResponse) {\n      if (this.useBackendError) {\n        this.toastService.error(error.error.map((error: { message: string }) => error.message).join(' '));\n      } else {\n        this.toastService.error(this.httpErrorMessages[error.status] || 'Unexpected error occurred.');\n      }\n    }\n\n    return throwError(() => error);\n  }\n\n  /**\n   * Handle response data - update cache and dispatch event if it is needed\n   */\n  protected handleResponse(response: Model[], method: HttpMethod) {\n    if (this.getCache() !== undefined) {\n      this.updateCache(response, method);\n    }\n\n    // dispatch event for interested services\n    if (response[0] instanceof ObservableModel) {\n      this.dispatchEvent(method, response as unknown as ObservableModel[]);\n    }\n  }\n\n  /**\n   * Update cache with passed items. Add/Update detects automatically, Delete via optional flag\n   */\n  protected updateCache(items: Model[], method: HttpMethod): void {\n    let cache: CollectionModel;\n\n    switch (method) {\n      case 'post':\n        cache = this.orderByDesc ? this.cache.unshift(...items) : this.cache.push(...items);\n        break;\n\n      case 'put':\n        // @TODO Alex old instance\n        items.forEach((item: Model) => {\n          cache = this.cache.replaceBy('id', item.id, item);\n        });\n        break;\n\n      case 'delete':\n        cache = this.cache.removeBy('id', items.map((item: Model) => item.id));\n        break;\n\n      case 'get':\n        cache = this.createCollectionInstance(this.collectionClass, items);\n    }\n\n    this.setCache(cache.toArray(), true);\n  }\n\n  /**\n   * Generate and dispatch rest event\n   */\n  protected dispatchEvent(method: HttpMethod, items: ObservableModel[]): void {\n    const eventName: string = this.modelClass.getEventName(method);\n    this.eventDispatcherService.dispatch2(new AppEvent2(eventName, items));\n  }\n\n  /**\n   * Check if method is not disabled. Throw exception otherwise.\n   * Some entities does not have endpoints for all methods.\n   */\n  private handleAccessError(method: RestMethod): void {\n    if (!this.disabledMethods.includes(method)) {\n      return;\n    }\n\n    throw new Error(`Method ${method}() is not allowed for ${this.constructor.name}`);\n  }\n\n  /**\n   * Subscribe to http events and run callback.\n   * CSE - Cleint Sent Events\n   * @param modelClass\n   * @param methods The list of http methods should be listened for\n   * @param callback The function to be called when event triggered\n   */\n  protected listenCSE(modelClass: typeof ObservableModel, callback: Function, methods: HttpMethod[] = ['post', 'put', 'delete']): void {\n    callback = callback.bind(this);\n\n    methods.forEach((method: HttpMethod) => {\n      this.eventDispatcherService.on2(modelClass.getEventName(method)).subscribe((data: ObservableModel[]) => {\n        callback(data);\n      });\n    })\n  }\n\n  /**\n   * check if user has subscription role to access api\n   */\n  hasRoles(): boolean {\n    if (!this.roles.length) {\n      return true;\n    }\n\n    return !!intersection(JSON.parse(localStorage.getItem('roles')), this.roles).length;\n  }\n\n  /**\n   * Listen for Server-Sent Events (SSE) on the specified Mercure topic\n   */\n  listenSSE(): void {\n    if (!this.mercureTopic) {\n      return;\n    }\n\n    this.sseService.on(this.mercureTopic).pipe(\n      map((response: object) => {\n        let model = this.createModelInstance(response);\n        let method: HttpMethod;\n        if (model.id) {\n          method = this.hasInCache(model.id) ? 'put' : 'post';\n        } else {\n          method = 'delete';\n          // we got empty body when item deleted, so we should get id from Api Platform data (@id)\n          model = merge(model, { id: +last(model['@id'].split('/')) });\n        }\n\n        return { method, model };\n      })\n    ).subscribe((change) => {\n      this.handleResponse([change.model], change.method)\n    });\n  }\n}\n"]}
334
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rest.service.js","sourceRoot":"","sources":["../../../../../../../../projects/tt-core/src/lib/services/http/rest/rest.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, inject } from '@angular/core';\nimport { Observable, ReplaySubject, of, throwError } from 'rxjs';\nimport { catchError, first, map } from 'rxjs/operators';\nimport { HttpClient, HttpErrorResponse } from '@angular/common/http';\nimport { EventDispatcherService, SseService } from '../../event';\nimport { classToPlain } from 'class-transformer';\nimport { Collection } from '../../../collections';\nimport { AbstractModel, ObservableModel } from '../../../db/Models';\nimport { AppEvent2 } from '../../../models';\nimport { toArray } from '../../../functions/array';\nimport { RestMethod } from './rest-method.type';\nimport { HttpMethod } from './http-method.type';\nimport { DataService } from '../../data.service';\nimport { UserRolesEnum } from 'taxtank-core/common';\nimport { ToastService } from '../../toast';\nimport merge from 'lodash/merge';\nimport intersection from 'lodash/intersection';\nimport last from 'lodash/last';\nimport cloneDeep from 'lodash/cloneDeep';\nimport { HTTP_ERROR_MESSAGES } from './http-error-messages.const';\n\n/**\n * @TODO refactor to behavior subject?\n * Abstract base service that implements common services functionality\n * and describe abstract methods/properties that have to be implemented in child services\n * Model - entity service is working with\n * BaseModel - base entity model that extends by Model\n * CollectionModel - entity collection class\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport abstract class RestService<BaseModel, Model extends AbstractModel, CollectionModel extends Collection<Model>>\n  extends DataService<BaseModel, Model, CollectionModel> {\n\n  /**\n   * Url part for service entity API\n   */\n  protected abstract endpointUri: string;\n\n  /**\n   * Subject for service cache\n   */\n  protected cacheSubject: ReplaySubject<CollectionModel> = new ReplaySubject(1);\n\n  /**\n   * List of methods unavailable for current API\n   * @TODO Alex: add and handle enabled methods too\n   * @TODO Alex: disable batch by default\n   */\n  disabledMethods: RestMethod[] = [];\n  protected sseService: SseService = inject(SseService);\n  protected toastService: ToastService = inject(ToastService);\n  protected http: HttpClient = inject(HttpClient);\n  protected eventDispatcherService: EventDispatcherService = inject(EventDispatcherService);\n  /**\n   * adds new entities to the beginning when true\n   * @TODO make true by default when all services refactored\n   */\n  protected orderByDesc = false;\n\n  roles: UserRolesEnum[] = [];\n  mercureTopic: string;\n  /**\n   * flag to use error messages from api or default ones\n   * @TODO: TT-4642 check customHttpErrorMessages fix change to backend errors\n   */\n  protected useBackendError = false;\n\n  /**\n   * mapping with HTTP errors codes and general messages\n   */\n  protected httpErrorMessages: {[key: number]: string};\n\n  constructor(@Inject('environment') protected environment: any) {\n    super();\n    this.httpErrorMessages = { ...HTTP_ERROR_MESSAGES, ...this.getCustomHttpErrorMessages() };\n  }\n\n  protected get apiUrl(): string {\n    return `${this.environment.apiV2}/${this.endpointUri}`;\n  }\n\n  setCache(data: any[], next = false): void {\n    super.setCache(data);\n\n    if (next) {\n      this.cacheSubject.next(this.cache);\n    }\n  }\n\n  /**\n   * Refresh cache with actual backend data\n   */\n  refreshCache(): void {\n    this.cache = undefined;\n    this.get();\n  }\n\n  /**\n   * perform a shallow copy of the emitted data to make it immutable\n   */\n  getCacheSubjectObservable(): Observable<CollectionModel> {\n    return this.cacheSubject.asObservable().pipe(map((cache) => cloneDeep(cache)));\n  }\n\n  /**\n   * Get data from backend and fill the cache\n   */\n  fetch(path = this.apiUrl, cache = true, queryParams = {}): Observable<CollectionModel> {\n    if (cache) {\n      // Set cache as empty collection to avoid multiple requests before cache filled\n      this.setCache([]);\n    }\n\n    return this.http.get(path, queryParams)\n      .pipe(\n        map((response: object | object[]) => Array.isArray(response) ? response : toArray(response)),\n        map((response: BaseModel[]) => {\n          if (cache) {\n            this.setCache(response, true);\n          }\n\n          return this.createCollectionInstance(this.collectionClass, response);\n        }),\n        catchError((error: unknown) => this.handleError(error))\n      );\n  }\n\n  get(path: string = this.apiUrl): Observable<CollectionModel> {\n    this.handleAccessError('get');\n\n    if (!this.hasRoles()) {\n      return of(this.createCollectionInstance(this.collectionClass, []));\n    }\n\n    if (!this.cache) {\n      this.fetch(path).pipe(first()).subscribe();\n    }\n\n    return this.getCacheSubjectObservable();\n  }\n\n  getBy(path: string, values: any): Observable<CollectionModel> {\n    return this.get().pipe(map((projects) => projects.filterBy(path, values)));\n  }\n\n  getFirst(): Observable<Model> {\n    return this.get().pipe(map((collection: CollectionModel) => collection.first));\n  }\n\n  hasInCache(id: number): boolean {\n    return !!this.getCache()?.findBy('id', id);\n  }\n\n  getArray(): Observable<Model[]> {\n    return this.get().pipe(map((collection: CollectionModel) => collection.toArray()));\n  }\n\n  getArrayBy(path: string, values: any): Observable<Model[]> {\n    return this.getBy(path, values).pipe(map((collection: CollectionModel) => collection.toArray()));\n  }\n\n  /**\n   * Create a new Model instance in database\n   */\n  post(model: Model, path: string = this.apiUrl): Observable<Model> {\n    this.handleAccessError('post');\n\n    return this.http.post(path, classToPlain(model))\n      .pipe(\n        map((response: object) => {\n          const result: Model = this.createModelInstance(response);\n          if (!this.mercureTopic) {\n            this.handleResponse([result], 'post');\n          }\n\n          return result;\n        }),\n        catchError((error: unknown) => this.handleError(error))\n      );\n  }\n\n  /**\n   * Create multiple new Model instances in database\n   */\n  postBatch(models: Model[]): Observable<Model[]> {\n    this.handleAccessError('postBatch');\n\n    return this.http.post(this.apiUrl, classToPlain(models))\n      .pipe(\n        map((response: object[]) => {\n          const result: Model[] = response.map((item: object): Model => this.createModelInstance(item));\n          if (!this.mercureTopic) {\n            this.handleResponse(result, 'post');\n          }\n\n          return result;\n        }),\n        catchError((error: unknown) => this.handleError(error))\n      );\n  }\n\n  /**\n   * Change an existing Model instance in database\n   */\n  put(model: Model, path = `${this.apiUrl}/${model.id}`): Observable<Model> {\n    this.handleAccessError('put');\n\n    return this.http.put(path, classToPlain(model))\n      .pipe(\n        map((response: object) => {\n          const result: Model = this.createModelInstance(response);\n          if (!this.mercureTopic) {\n            this.handleResponse([result], 'put');\n          }\n\n          return result;\n        }),\n        catchError((error: unknown) => this.handleError(error))\n      );\n  }\n\n  /**\n   * Change multiple existing Model instances in database\n   */\n  putBatch(models: Model[]): Observable<Model[]> {\n    this.handleAccessError('putBatch');\n\n    return this.http.put(this.apiUrl, classToPlain(models))\n      .pipe(\n        map((response: object[]) => {\n          const result: Model[] = response.map((item: object): Model => this.createModelInstance(item));\n          if (!this.mercureTopic) {\n            this.handleResponse(result, 'put');\n          }\n\n          return result;\n        })\n      );\n  }\n\n  /**\n   * Remove a Model instance from database\n   */\n  delete(model: Model, path = `${this.apiUrl}/${model.id}`): Observable<void> {\n    this.handleAccessError('delete');\n\n    return this.http.delete(path)\n      .pipe(\n        map(() => {\n          if (!this.mercureTopic) {\n            this.handleResponse([model], 'delete');\n          }\n        }),\n        catchError((error: unknown) => this.handleError(error))\n      );\n  }\n\n  /**\n   * Remove multiple Model instances from database\n   */\n  deleteBatch(models: Model[]): Observable<void> {\n    this.handleAccessError('deleteBatch');\n\n    return this.http.post(`${this.apiUrl}/delete`, classToPlain(models))\n      .pipe(\n        map(() => {\n          if (!this.mercureTopic) {\n            this.handleResponse(models, 'delete');\n          }\n        }),\n        catchError((error: unknown) => this.handleError(error))\n      );\n  }\n\n  /**\n   * method with messages that can be redefined in other classes to customize httpErrorMessages\n   */\n  protected getCustomHttpErrorMessages(): Record<number, string> {\n    return {}\n  }\n  /**\n   * Handle response errors - shows error in toast\n   * and throws error further\n   * @param error - any backend error\n   * @throws HttpErrorResponse | Error - Always throws the error further as an Observable<never>\n   */\n  handleError(error: unknown) {\n    if (error instanceof HttpErrorResponse) {\n      if (this.useBackendError) {\n        this.toastService.error(error.error.map((error: { message: string }) => error.message).join(' '));\n      } else {\n        this.toastService.error(this.httpErrorMessages[error.status] || 'Unexpected error occurred.');\n      }\n    }\n\n    return throwError(() => error);\n  }\n\n  /**\n   * Handle response data - update cache and dispatch event if it is needed\n   */\n  protected handleResponse(response: Model[], method: HttpMethod) {\n    if (this.getCache() !== undefined) {\n      this.updateCache(response, method);\n    }\n\n    // dispatch event for interested services\n    if (response[0] instanceof ObservableModel) {\n      this.dispatchEvent(method, response as unknown as ObservableModel[]);\n    }\n  }\n\n  /**\n   * Update cache with passed items. Add/Update detects automatically, Delete via optional flag\n   */\n  protected updateCache(items: Model[], method: HttpMethod): void {\n    let cache: CollectionModel;\n\n    switch (method) {\n      case 'post':\n        cache = this.orderByDesc ? this.cache.unshift(...items) : this.cache.push(...items);\n        break;\n\n      case 'put':\n        // @TODO Alex old instance\n        items.forEach((item: Model) => {\n          cache = this.cache.replaceBy('id', item.id, item);\n        });\n        break;\n\n      case 'delete':\n        cache = this.cache.removeBy('id', items.map((item: Model) => item.id));\n        break;\n\n      // case 'get':\n      //   cache = this.createCollectionInstance(this.collectionClass, items);\n    }\n\n    this.setCache(cache.toArray(), true);\n  }\n\n  /**\n   * Generate and dispatch rest event\n   */\n  protected dispatchEvent(method: HttpMethod, items: ObservableModel[]): void {\n    const eventName: string = this.modelClass.getEventName(method);\n    this.eventDispatcherService.dispatch2(new AppEvent2(eventName, items));\n  }\n\n  /**\n   * Check if method is not disabled. Throw exception otherwise.\n   * Some entities does not have endpoints for all methods.\n   */\n  private handleAccessError(method: RestMethod): void {\n    if (!this.disabledMethods.includes(method)) {\n      return;\n    }\n\n    throw new Error(`Method ${method}() is not allowed for ${this.constructor.name}`);\n  }\n\n  /**\n   * Subscribe to http events and run callback.\n   * CSE - Cleint Sent Events\n   * @param modelClass\n   * @param methods The list of http methods should be listened for\n   * @param callback The function to be called when event triggered\n   */\n  protected listenCSE(modelClass: typeof ObservableModel, callback: Function, methods: HttpMethod[] = ['post', 'put', 'delete']): void {\n    callback = callback.bind(this);\n\n    methods.forEach((method: HttpMethod) => {\n      this.eventDispatcherService.on2(modelClass.getEventName(method)).subscribe((data: ObservableModel[]) => {\n        callback(data);\n      });\n    })\n  }\n\n  /**\n   * check if user has subscription role to access api\n   */\n  hasRoles(): boolean {\n    if (!this.roles.length) {\n      return true;\n    }\n\n    return !!intersection(JSON.parse(localStorage.getItem('roles')), this.roles).length;\n  }\n\n  /**\n   * Listen for Server-Sent Events (SSE) on the specified Mercure topic\n   */\n  listenSSE(): void {\n    if (!this.mercureTopic) {\n      return;\n    }\n\n    this.sseService.on(this.mercureTopic).pipe(\n      map((response: object) => {\n        let model = this.createModelInstance(response);\n        let method: HttpMethod;\n        if (model.id) {\n          method = this.hasInCache(model.id) ? 'put' : 'post';\n        } else {\n          method = 'delete';\n          // we got empty body when item deleted, so we should get id from Api Platform data (@id)\n          model = merge(model, { id: +last(model['@id'].split('/')) });\n        }\n\n        return { method, model };\n      })\n    ).subscribe((change) => {\n      this.handleResponse([change.model], change.method)\n    });\n  }\n}\n"]}