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.
- package/esm2022/src/lib/services/data.service.mjs +4 -4
- package/esm2022/src/lib/services/http/bank/bank-account/bank-account.service.mjs +18 -2
- package/esm2022/src/lib/services/http/bank/bank-connection/bank-connection.service.mjs +17 -5
- package/esm2022/src/lib/services/http/firm/client-movement/client-movement.service.mjs +4 -18
- package/esm2022/src/lib/services/http/holding/holding-type.service.mjs +9 -9
- package/esm2022/src/lib/services/http/rest/rest.service.mjs +13 -9
- package/esm2022/src/lib/services/xlsx/xlsx.service.mjs +18 -10
- package/fesm2022/taxtank-core.mjs +125 -100
- package/fesm2022/taxtank-core.mjs.map +1 -1
- package/package.json +1 -1
- package/src/lib/services/data.service.d.ts +1 -1
- package/src/lib/services/http/bank/bank-account/bank-account.service.d.ts +1 -0
- package/src/lib/services/http/bank/bank-connection/bank-connection.service.d.ts +1 -1
- package/src/lib/services/http/firm/client-movement/client-movement.service.d.ts +1 -1
- package/src/lib/services/http/holding/holding-type.service.d.ts +4 -0
- package/src/lib/services/http/rest/rest.service.d.ts +1 -1
- package/src/lib/services/xlsx/xlsx.service.d.ts +7 -0
@@ -39,15 +39,8 @@ export class XlsxService {
|
|
39
39
|
// add caption for the current table
|
40
40
|
xlsx.utils.sheet_add_aoa(worksheet, [[data.caption?.innerText]], { origin: -1 });
|
41
41
|
// Prepare to add table data to the worksheet, processing each cell
|
42
|
-
const rows = Array.from(data.rows)
|
43
|
-
|
44
|
-
// Convert currency strings like "$0.00" to numbers
|
45
|
-
if (/^-?\$/.test(cellValue)) {
|
46
|
-
// @TODO vik fix
|
47
|
-
// cellValue = parseFloat(cellValue.replace('$', ''));
|
48
|
-
}
|
49
|
-
return cellValue;
|
50
|
-
}));
|
42
|
+
const rows = Array.from(data.rows)
|
43
|
+
.map((row) => Array.from(row.cells).map(cell => this.htmlToXlsCell(cell)));
|
51
44
|
// Add the processed table data to the worksheet
|
52
45
|
xlsx.utils.sheet_add_aoa(worksheet, rows, { origin: -1 });
|
53
46
|
// set empty row after current table
|
@@ -56,6 +49,21 @@ export class XlsxService {
|
|
56
49
|
xlsx.utils.book_append_sheet(workbook, worksheet);
|
57
50
|
return xlsx.write(workbook, { bookType: 'xlsx', type: 'array' });
|
58
51
|
}
|
52
|
+
htmlToXlsCell(cell) {
|
53
|
+
const cellValue = cell.innerText;
|
54
|
+
// regex to check currency value
|
55
|
+
return /^-?\$/.test(cellValue) ? this.currencyToNumber(cellValue) : cellValue;
|
56
|
+
}
|
57
|
+
/**
|
58
|
+
* function which reconverts values from customCurrencyPipe
|
59
|
+
* @param cellValue - string with $ and possibly comma. $123,123.03
|
60
|
+
* @returns value without $ and comma. like 123123.03
|
61
|
+
*/
|
62
|
+
currencyToNumber(cellValue) {
|
63
|
+
// remove dollar sign and comma
|
64
|
+
cellValue = cellValue.replace(/[$,]/g, '');
|
65
|
+
return parseFloat(cellValue);
|
66
|
+
}
|
59
67
|
/**
|
60
68
|
* @TODO vik/artem work with ExportDataTable instead of ExportableCollection
|
61
69
|
* @TODO vik/artem why so much code? here is 6 rows solution https://stackoverflow.com/questions/64939994/how-to-export-array-of-objects-to-an-excel-in-angular-8
|
@@ -91,4 +99,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
91
99
|
providedIn: 'root'
|
92
100
|
}]
|
93
101
|
}] });
|
94
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xlsx.service.js","sourceRoot":"","sources":["../../../../../../../projects/tt-core/src/lib/services/xlsx/xlsx.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport * as xlsx from 'xlsx';\nimport * as FileSaver from 'file-saver';\nimport { ExportableCollection } from '../../collections';\nimport { ExportDataTable } from '../../models/export/export-data-table';\n\nconst EXCEL_TYPE: string = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8'\n\n@Injectable({\n  providedIn: 'root'\n})\n\n/**\n * Service to work with XLSX (generate, download, e.t.c.)\n */\nexport class XlsxService {\n  /**\n   * Export file form provided HTML tables\n   */\n  exportTables(tables: NodeListOf<HTMLTableElement>, title: string, fileName: string): void {\n    const excelFile: BlobPart = this.generateFromTables(tables, title);\n    const data: Blob = new Blob([excelFile], {\n      type: EXCEL_TYPE\n    });\n\n    FileSaver.saveAs(data, `${fileName}.xlsx`);\n  }\n\n  private generateFromTables(tables: NodeListOf<HTMLTableElement>, title?: string): BlobPart {\n    // create new workbook\n    const workbook: xlsx.WorkBook = xlsx.utils.book_new();\n    // create empty worksheet\n    const worksheet: xlsx.WorkSheet = {\n      SheetNames: [],\n      Sheets: {}\n    };\n\n    tables.forEach((data: HTMLTableElement) => {\n      // add caption for the current table\n      xlsx.utils.sheet_add_aoa(worksheet, [[data.caption?.innerText]], { origin: -1 });\n      // Prepare to add table data to the worksheet, processing each cell\n      const rows = Array.from(data.rows).map((row: HTMLTableRowElement) => Array.from(row.cells).map((cell: HTMLTableCellElement) => {\n        const cellValue: string | number = cell.innerText;\n        // Convert currency strings like \"$0.00\" to numbers\n        if (/^-?\\$/.test(cellValue)) {\n          // @TODO vik fix\n          // cellValue = parseFloat(cellValue.replace('$', ''));\n        }\n\n        return cellValue;\n      }));\n      // Add the processed table data to the worksheet\n      xlsx.utils.sheet_add_aoa(worksheet, rows, { origin: -1 });\n      // set empty row after current table\n      xlsx.utils.sheet_add_aoa(worksheet, [], { origin: -1 });\n    });\n\n    xlsx.utils.book_append_sheet(workbook, worksheet);\n    return xlsx.write(workbook, { bookType: 'xlsx', type: 'array' });\n  }\n\n  getFileName = (name: string) => {\n    const sheetName = name || 'ExportResult';\n    const fileName = `${sheetName}`;\n    return {\n      sheetName,\n      fileName\n    };\n  };\n\n  /**\n   * @TODO vik/artem work with ExportDataTable instead of ExportableCollection\n   * @TODO vik/artem why so much code? here is 6 rows solution https://stackoverflow.com/questions/64939994/how-to-export-array-of-objects-to-an-excel-in-angular-8\n   */\n  exportArrayToExcel(exportableCollection: ExportableCollection<any>, name?: string, params? : any) {\n    const workbook: xlsx.WorkBook = xlsx.utils.book_new();\n    // create empty worksheet\n    const worksheet: xlsx.WorkSheet = {\n      SheetNames: [],\n      Sheets: {}\n    };\n\n    const exportData: ExportDataTable = exportableCollection.export(params)\n    const exportAoa = exportableCollection.getBodyAoa(exportData);\n    const { sheetName, fileName } = this.getFileName(name);\n\n    xlsx.utils.sheet_add_aoa(worksheet, [exportData.header], { origin: -1 });\n    // add table table data to the worksheet\n    xlsx.utils.sheet_add_aoa(worksheet, exportAoa, { origin: -1 });\n    // set empty row after current table\n    xlsx.utils.sheet_add_aoa(worksheet, [], { origin: -1 });\n\n    xlsx.utils.book_append_sheet(workbook, worksheet);\n    const excelFile: BlobPart = xlsx.write(workbook, { bookType: 'xlsx', type: 'array' });\n\n    const data: Blob = new Blob([excelFile], {\n      type: EXCEL_TYPE\n    });\n    FileSaver.saveAs(data, `${fileName}.xlsx`);\n  }\n}\n"]}
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xlsx.service.js","sourceRoot":"","sources":["../../../../../../../projects/tt-core/src/lib/services/xlsx/xlsx.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport * as xlsx from 'xlsx';\nimport * as FileSaver from 'file-saver';\nimport { ExportableCollection } from '../../collections';\nimport { ExportDataTable } from '../../models/export/export-data-table';\n\nconst EXCEL_TYPE: string = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8'\n\n@Injectable({\n  providedIn: 'root'\n})\n\n/**\n * Service to work with XLSX (generate, download, e.t.c.)\n */\nexport class XlsxService {\n  /**\n   * Export file form provided HTML tables\n   */\n  exportTables(tables: NodeListOf<HTMLTableElement>, title: string, fileName: string): void {\n    const excelFile: BlobPart = this.generateFromTables(tables, title);\n    const data: Blob = new Blob([excelFile], {\n      type: EXCEL_TYPE\n    });\n\n    FileSaver.saveAs(data, `${fileName}.xlsx`);\n  }\n\n  private generateFromTables(tables: NodeListOf<HTMLTableElement>, title?: string): BlobPart {\n    // create new workbook\n    const workbook: xlsx.WorkBook = xlsx.utils.book_new();\n    // create empty worksheet\n    const worksheet: xlsx.WorkSheet = {\n      SheetNames: [],\n      Sheets: {}\n    };\n\n    tables.forEach((data: HTMLTableElement) => {\n      // add caption for the current table\n      xlsx.utils.sheet_add_aoa(worksheet, [[data.caption?.innerText]], { origin: -1 });\n      // Prepare to add table data to the worksheet, processing each cell\n      const rows = Array.from(data.rows)\n        .map((row: HTMLTableRowElement) => Array.from(row.cells).map(cell => this.htmlToXlsCell(cell)));\n      // Add the processed table data to the worksheet\n      xlsx.utils.sheet_add_aoa(worksheet, rows, { origin: -1 });\n      // set empty row after current table\n      xlsx.utils.sheet_add_aoa(worksheet, [], { origin: -1 });\n    });\n\n    xlsx.utils.book_append_sheet(workbook, worksheet);\n    return xlsx.write(workbook, { bookType: 'xlsx', type: 'array' });\n  }\n\n  htmlToXlsCell(cell: HTMLTableCellElement): string | number {\n    const cellValue: string | number = cell.innerText;\n    // regex to check currency value\n    return /^-?\\$/.test(cellValue) ? this.currencyToNumber(cellValue) : cellValue;\n  }\n\n  /**\n   * function which reconverts values from customCurrencyPipe\n   * @param cellValue - string with $ and possibly comma.  $123,123.03\n   * @returns value without $ and comma. like 123123.03\n   */\n  currencyToNumber(cellValue: string): number {\n    // remove dollar sign and comma\n    cellValue = cellValue.replace(/[$,]/g, '');\n\n    return parseFloat(cellValue);\n  }\n\n  getFileName = (name: string) => {\n    const sheetName = name || 'ExportResult';\n    const fileName = `${sheetName}`;\n    return {\n      sheetName,\n      fileName\n    };\n  };\n\n  /**\n   * @TODO vik/artem work with ExportDataTable instead of ExportableCollection\n   * @TODO vik/artem why so much code? here is 6 rows solution https://stackoverflow.com/questions/64939994/how-to-export-array-of-objects-to-an-excel-in-angular-8\n   */\n  exportArrayToExcel(exportableCollection: ExportableCollection<any>, name?: string, params? : any) {\n    const workbook: xlsx.WorkBook = xlsx.utils.book_new();\n    // create empty worksheet\n    const worksheet: xlsx.WorkSheet = {\n      SheetNames: [],\n      Sheets: {}\n    };\n\n    const exportData: ExportDataTable = exportableCollection.export(params)\n    const exportAoa = exportableCollection.getBodyAoa(exportData);\n    const { sheetName, fileName } = this.getFileName(name);\n\n    xlsx.utils.sheet_add_aoa(worksheet, [exportData.header], { origin: -1 });\n    // add table table data to the worksheet\n    xlsx.utils.sheet_add_aoa(worksheet, exportAoa, { origin: -1 });\n    // set empty row after current table\n    xlsx.utils.sheet_add_aoa(worksheet, [], { origin: -1 });\n\n    xlsx.utils.book_append_sheet(workbook, worksheet);\n    const excelFile: BlobPart = xlsx.write(workbook, { bookType: 'xlsx', type: 'array' });\n\n    const data: Blob = new Blob([excelFile], {\n      type: EXCEL_TYPE\n    });\n    FileSaver.saveAs(data, `${fileName}.xlsx`);\n  }\n}\n"]}
|
@@ -11279,8 +11279,8 @@ class DataService {
|
|
11279
11279
|
createModelInstance(model) {
|
11280
11280
|
return plainToClass(this.modelClass, model);
|
11281
11281
|
}
|
11282
|
-
createCollectionInstance(collectionClass,
|
11283
|
-
return new collectionClass(
|
11282
|
+
createCollectionInstance(collectionClass, data) {
|
11283
|
+
return new collectionClass(data.map((item) => this.createModelInstance(item)));
|
11284
11284
|
}
|
11285
11285
|
/**
|
11286
11286
|
* never return cache directly to prevent update
|
@@ -11298,7 +11298,7 @@ class DataService {
|
|
11298
11298
|
* @TODO vik any[] because of problems with base models extending abstractModel
|
11299
11299
|
*/
|
11300
11300
|
setCache(data) {
|
11301
|
-
this.cache = this.createCollectionInstance(this.collectionClass, data
|
11301
|
+
this.cache = this.createCollectionInstance(this.collectionClass, data);
|
11302
11302
|
}
|
11303
11303
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DataService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
11304
11304
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DataService, providedIn: 'root' }); }
|
@@ -11388,13 +11388,17 @@ let RestService$1 = class RestService extends DataService {
|
|
11388
11388
|
/**
|
11389
11389
|
* Get data from backend and fill the cache
|
11390
11390
|
*/
|
11391
|
-
fetch(path = this.apiUrl, cache = true) {
|
11392
|
-
|
11393
|
-
|
11394
|
-
|
11391
|
+
fetch(path = this.apiUrl, cache = true, queryParams = {}) {
|
11392
|
+
if (cache) {
|
11393
|
+
// Set cache as empty collection to avoid multiple requests before cache filled
|
11394
|
+
this.setCache([]);
|
11395
|
+
}
|
11396
|
+
return this.http.get(path, queryParams)
|
11395
11397
|
.pipe(map((response) => Array.isArray(response) ? response : toArray(response)), map((response) => {
|
11396
|
-
|
11397
|
-
|
11398
|
+
if (cache) {
|
11399
|
+
this.setCache(response, true);
|
11400
|
+
}
|
11401
|
+
return this.createCollectionInstance(this.collectionClass, response);
|
11398
11402
|
}), catchError((error) => this.handleError(error)));
|
11399
11403
|
}
|
11400
11404
|
get(path = this.apiUrl) {
|
@@ -11555,8 +11559,8 @@ let RestService$1 = class RestService extends DataService {
|
|
11555
11559
|
case 'delete':
|
11556
11560
|
cache = this.cache.removeBy('id', items.map((item) => item.id));
|
11557
11561
|
break;
|
11558
|
-
case 'get':
|
11559
|
-
|
11562
|
+
// case 'get':
|
11563
|
+
// cache = this.createCollectionInstance(this.collectionClass, items);
|
11560
11564
|
}
|
11561
11565
|
this.setCache(cache.toArray(), true);
|
11562
11566
|
}
|
@@ -11637,6 +11641,58 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
11637
11641
|
args: ['environment']
|
11638
11642
|
}] }] });
|
11639
11643
|
|
11644
|
+
var UserEventTypeTypeEnum;
|
11645
|
+
(function (UserEventTypeTypeEnum) {
|
11646
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["REGISTERED"] = 1000] = "REGISTERED";
|
11647
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PASSWORD_RESET_REQUEST"] = 1001] = "PASSWORD_RESET_REQUEST";
|
11648
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["APP_FEATURES"] = 1010] = "APP_FEATURES";
|
11649
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["SUBSCRIBED"] = 2000] = "SUBSCRIBED";
|
11650
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["UNSUBSCRIBED"] = 2001] = "UNSUBSCRIBED";
|
11651
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["SUBSCRIPTION_UPDATE"] = 2004] = "SUBSCRIPTION_UPDATE";
|
11652
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["SUBSCRIPTION_TRIAL_UPDATE"] = 2005] = "SUBSCRIPTION_TRIAL_UPDATE";
|
11653
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["SUBSCRIPTION_PAYMENT_FAILED"] = 2006] = "SUBSCRIPTION_PAYMENT_FAILED";
|
11654
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["CLIENT_INVITE"] = 2010] = "CLIENT_INVITE";
|
11655
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["CLIENT_INVITE_TO_REGISTER"] = 2011] = "CLIENT_INVITE_TO_REGISTER";
|
11656
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["FIRM_INVITE_ACCEPTED"] = 2012] = "FIRM_INVITE_ACCEPTED";
|
11657
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["FIRM_INVITE_REJECTED"] = 2013] = "FIRM_INVITE_REJECTED";
|
11658
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["FIRM_INVITE_REGISTERED"] = 2014] = "FIRM_INVITE_REGISTERED";
|
11659
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PROPERTY_SHARE_INVITE"] = 2020] = "PROPERTY_SHARE_INVITE";
|
11660
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PROPERTY_SHARE_INVITE_TO_REGISTER"] = 2021] = "PROPERTY_SHARE_INVITE_TO_REGISTER";
|
11661
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PROPERTY_SHARE_INVITE_ACCEPTED"] = 2022] = "PROPERTY_SHARE_INVITE_ACCEPTED";
|
11662
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PROPERTY_SHARE_INVITE_REJECTED"] = 2023] = "PROPERTY_SHARE_INVITE_REJECTED";
|
11663
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PROPERTY_SHARE_INVITE_REGISTERED"] = 2024] = "PROPERTY_SHARE_INVITE_REGISTERED";
|
11664
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PROPERTY_SHARE_CHANGE_REQUESTED"] = 2025] = "PROPERTY_SHARE_CHANGE_REQUESTED";
|
11665
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PROPERTY_SHARE_CHANGE_ACCEPTED"] = 2026] = "PROPERTY_SHARE_CHANGE_ACCEPTED";
|
11666
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PROPERTY_SHARE_CHANGE_REJECTED"] = 2027] = "PROPERTY_SHARE_CHANGE_REJECTED";
|
11667
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["OWNER_SUBSCRIBED"] = 2028] = "OWNER_SUBSCRIBED";
|
11668
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["OWNER_UNSUBSCRIBED"] = 2029] = "OWNER_UNSUBSCRIBED";
|
11669
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["BASIQ_NEW_ACCOUNTS"] = 2030] = "BASIQ_NEW_ACCOUNTS";
|
11670
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["BASIQ_FIRST_IMPORT_COMPLETE"] = 2031] = "BASIQ_FIRST_IMPORT_COMPLETE";
|
11671
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["BASIQ_AUTHORIZATION_FAIL"] = 2032] = "BASIQ_AUTHORIZATION_FAIL";
|
11672
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["TRANSACTION_ALLOCATE_REMINDER"] = 2033] = "TRANSACTION_ALLOCATE_REMINDER";
|
11673
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["INVOICE_AUTO_ALLOCATED"] = 2035] = "INVOICE_AUTO_ALLOCATED";
|
11674
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["INVOICE_AUTO_PART_ALLOCATED"] = 2036] = "INVOICE_AUTO_PART_ALLOCATED";
|
11675
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["RULES_AUTO_ALLOCATED"] = 2037] = "RULES_AUTO_ALLOCATED";
|
11676
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["REGISTRATION_INVITE"] = 2040] = "REGISTRATION_INVITE";
|
11677
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["REGISTRATION_INVITE_ACCEPTED"] = 2041] = "REGISTRATION_INVITE_ACCEPTED";
|
11678
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["CLIENT_EMAIL_CONFIRMED"] = 2050] = "CLIENT_EMAIL_CONFIRMED";
|
11679
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["TAX_REVIEW_REQUESTED"] = 2060] = "TAX_REVIEW_REQUESTED";
|
11680
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["FIRM_INVITE_TO_REGISTER"] = 3000] = "FIRM_INVITE_TO_REGISTER";
|
11681
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["FIRM_INVITE"] = 3001] = "FIRM_INVITE";
|
11682
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["CLIENT_INVITE_ACCEPTED"] = 3002] = "CLIENT_INVITE_ACCEPTED";
|
11683
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["CLIENT_INVITE_REJECTED"] = 3003] = "CLIENT_INVITE_REJECTED";
|
11684
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["CLIENT_INVITE_REGISTERED"] = 3004] = "CLIENT_INVITE_REGISTERED";
|
11685
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["FIRM_NEW_CLIENT"] = 3005] = "FIRM_NEW_CLIENT";
|
11686
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["FIRM_LOST_CLIENT"] = 3006] = "FIRM_LOST_CLIENT";
|
11687
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["EMPLOYEE_INVITE"] = 3010] = "EMPLOYEE_INVITE";
|
11688
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["EMPLOYEE_LOST_CLIENT"] = 3011] = "EMPLOYEE_LOST_CLIENT";
|
11689
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["EMPLOYEE_NEW_CLIENT"] = 3012] = "EMPLOYEE_NEW_CLIENT";
|
11690
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["EMPLOYEE_INVITE_ACCEPTED"] = 3013] = "EMPLOYEE_INVITE_ACCEPTED";
|
11691
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["EMPLOYEE_EMAIL_CONFIRMED"] = 3020] = "EMPLOYEE_EMAIL_CONFIRMED";
|
11692
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["TAX_REVIEW_RECEIVED"] = 3030] = "TAX_REVIEW_RECEIVED";
|
11693
|
+
UserEventTypeTypeEnum[UserEventTypeTypeEnum["SHARESIGHT_IMPORT"] = 2070] = "SHARESIGHT_IMPORT";
|
11694
|
+
})(UserEventTypeTypeEnum || (UserEventTypeTypeEnum = {}));
|
11695
|
+
|
11640
11696
|
/**
|
11641
11697
|
* Service that handling user's bank accounts logic
|
11642
11698
|
*/
|
@@ -11662,10 +11718,12 @@ class BankAccountService extends RestService$1 {
|
|
11662
11718
|
*/
|
11663
11719
|
listenEvents() {
|
11664
11720
|
this.listenToEventDispatcherChanges();
|
11721
|
+
// @TODO why?
|
11665
11722
|
this.listenCSE(BankTransaction, this.refreshCache, ['post', 'delete']);
|
11666
11723
|
this.listenCSE(PropertyShare, this.refreshCache, ['put']);
|
11667
11724
|
this.listenCSE(BankConnection, this.refreshCache, ['post']);
|
11668
|
-
this.
|
11725
|
+
this.listenNotifications();
|
11726
|
+
// this.listenConnections();
|
11669
11727
|
}
|
11670
11728
|
/**
|
11671
11729
|
* Update bank account current balance
|
@@ -11699,6 +11757,19 @@ class BankAccountService extends RestService$1 {
|
|
11699
11757
|
this.refreshCache();
|
11700
11758
|
});
|
11701
11759
|
}
|
11760
|
+
listenNotifications() {
|
11761
|
+
this.eventDispatcherService.on(AppEventTypeEnum.NOTIFICATION_ADDED).subscribe((notification) => {
|
11762
|
+
const events = [
|
11763
|
+
UserEventTypeTypeEnum.BASIQ_NEW_ACCOUNTS,
|
11764
|
+
UserEventTypeTypeEnum.BASIQ_FIRST_IMPORT_COMPLETE,
|
11765
|
+
UserEventTypeTypeEnum.BASIQ_AUTHORIZATION_FAIL,
|
11766
|
+
];
|
11767
|
+
if (!notification.isRead && events.includes(notification.eventType)) {
|
11768
|
+
// @TODO TT-3826 move to unified mercure event
|
11769
|
+
this.refreshCache();
|
11770
|
+
}
|
11771
|
+
});
|
11772
|
+
}
|
11702
11773
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BankAccountService, deps: [{ token: i1.HttpClient }, { token: EventDispatcherService }, { token: SseService }, { token: 'environment' }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
11703
11774
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BankAccountService, providedIn: 'root' }); }
|
11704
11775
|
}
|
@@ -11750,12 +11821,10 @@ class BankConnectionService extends RestService$1 {
|
|
11750
11821
|
this.collectionClass = Collection;
|
11751
11822
|
this.endpointUri = 'bank-connections';
|
11752
11823
|
this.disabledMethods = ['postBatch', 'putBatch', 'delete', 'deleteBatch'];
|
11753
|
-
this.mercureTopic = 'bankConnections';
|
11754
11824
|
this.listenEvents();
|
11755
11825
|
}
|
11756
11826
|
listenEvents() {
|
11757
|
-
|
11758
|
-
this.listenSSE();
|
11827
|
+
this.listenNotifications();
|
11759
11828
|
}
|
11760
11829
|
/**
|
11761
11830
|
* there is no put BankConnection method, we have to post to update
|
@@ -11798,6 +11867,19 @@ class BankConnectionService extends RestService$1 {
|
|
11798
11867
|
deactivate(bankConnection) {
|
11799
11868
|
return this.put(bankConnection, `${this.apiUrl}/${bankConnection.id}/deactivate`);
|
11800
11869
|
}
|
11870
|
+
listenNotifications() {
|
11871
|
+
this.eventDispatcherService.on(AppEventTypeEnum.NOTIFICATION_ADDED).subscribe((notification) => {
|
11872
|
+
const events = [
|
11873
|
+
UserEventTypeTypeEnum.BASIQ_NEW_ACCOUNTS,
|
11874
|
+
UserEventTypeTypeEnum.BASIQ_FIRST_IMPORT_COMPLETE,
|
11875
|
+
UserEventTypeTypeEnum.BASIQ_AUTHORIZATION_FAIL,
|
11876
|
+
];
|
11877
|
+
if (!notification.isRead && events.includes(notification.eventType)) {
|
11878
|
+
// @TODO TT-3826 move to unified mercure event
|
11879
|
+
this.refreshCache();
|
11880
|
+
}
|
11881
|
+
});
|
11882
|
+
}
|
11801
11883
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BankConnectionService, deps: [{ token: 'environment' }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
11802
11884
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BankConnectionService, providedIn: 'root' }); }
|
11803
11885
|
}
|
@@ -11811,58 +11893,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
11811
11893
|
args: ['environment']
|
11812
11894
|
}] }] });
|
11813
11895
|
|
11814
|
-
var UserEventTypeTypeEnum;
|
11815
|
-
(function (UserEventTypeTypeEnum) {
|
11816
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["REGISTERED"] = 1000] = "REGISTERED";
|
11817
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PASSWORD_RESET_REQUEST"] = 1001] = "PASSWORD_RESET_REQUEST";
|
11818
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["APP_FEATURES"] = 1010] = "APP_FEATURES";
|
11819
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["SUBSCRIBED"] = 2000] = "SUBSCRIBED";
|
11820
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["UNSUBSCRIBED"] = 2001] = "UNSUBSCRIBED";
|
11821
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["SUBSCRIPTION_UPDATE"] = 2004] = "SUBSCRIPTION_UPDATE";
|
11822
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["SUBSCRIPTION_TRIAL_UPDATE"] = 2005] = "SUBSCRIPTION_TRIAL_UPDATE";
|
11823
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["SUBSCRIPTION_PAYMENT_FAILED"] = 2006] = "SUBSCRIPTION_PAYMENT_FAILED";
|
11824
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["CLIENT_INVITE"] = 2010] = "CLIENT_INVITE";
|
11825
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["CLIENT_INVITE_TO_REGISTER"] = 2011] = "CLIENT_INVITE_TO_REGISTER";
|
11826
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["FIRM_INVITE_ACCEPTED"] = 2012] = "FIRM_INVITE_ACCEPTED";
|
11827
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["FIRM_INVITE_REJECTED"] = 2013] = "FIRM_INVITE_REJECTED";
|
11828
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["FIRM_INVITE_REGISTERED"] = 2014] = "FIRM_INVITE_REGISTERED";
|
11829
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PROPERTY_SHARE_INVITE"] = 2020] = "PROPERTY_SHARE_INVITE";
|
11830
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PROPERTY_SHARE_INVITE_TO_REGISTER"] = 2021] = "PROPERTY_SHARE_INVITE_TO_REGISTER";
|
11831
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PROPERTY_SHARE_INVITE_ACCEPTED"] = 2022] = "PROPERTY_SHARE_INVITE_ACCEPTED";
|
11832
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PROPERTY_SHARE_INVITE_REJECTED"] = 2023] = "PROPERTY_SHARE_INVITE_REJECTED";
|
11833
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PROPERTY_SHARE_INVITE_REGISTERED"] = 2024] = "PROPERTY_SHARE_INVITE_REGISTERED";
|
11834
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PROPERTY_SHARE_CHANGE_REQUESTED"] = 2025] = "PROPERTY_SHARE_CHANGE_REQUESTED";
|
11835
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PROPERTY_SHARE_CHANGE_ACCEPTED"] = 2026] = "PROPERTY_SHARE_CHANGE_ACCEPTED";
|
11836
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["PROPERTY_SHARE_CHANGE_REJECTED"] = 2027] = "PROPERTY_SHARE_CHANGE_REJECTED";
|
11837
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["OWNER_SUBSCRIBED"] = 2028] = "OWNER_SUBSCRIBED";
|
11838
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["OWNER_UNSUBSCRIBED"] = 2029] = "OWNER_UNSUBSCRIBED";
|
11839
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["BASIQ_NEW_ACCOUNTS"] = 2030] = "BASIQ_NEW_ACCOUNTS";
|
11840
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["BASIQ_FIRST_IMPORT_COMPLETE"] = 2031] = "BASIQ_FIRST_IMPORT_COMPLETE";
|
11841
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["BASIQ_AUTHORIZATION_FAIL"] = 2032] = "BASIQ_AUTHORIZATION_FAIL";
|
11842
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["TRANSACTION_ALLOCATE_REMINDER"] = 2033] = "TRANSACTION_ALLOCATE_REMINDER";
|
11843
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["INVOICE_AUTO_ALLOCATED"] = 2035] = "INVOICE_AUTO_ALLOCATED";
|
11844
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["INVOICE_AUTO_PART_ALLOCATED"] = 2036] = "INVOICE_AUTO_PART_ALLOCATED";
|
11845
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["RULES_AUTO_ALLOCATED"] = 2037] = "RULES_AUTO_ALLOCATED";
|
11846
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["REGISTRATION_INVITE"] = 2040] = "REGISTRATION_INVITE";
|
11847
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["REGISTRATION_INVITE_ACCEPTED"] = 2041] = "REGISTRATION_INVITE_ACCEPTED";
|
11848
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["CLIENT_EMAIL_CONFIRMED"] = 2050] = "CLIENT_EMAIL_CONFIRMED";
|
11849
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["TAX_REVIEW_REQUESTED"] = 2060] = "TAX_REVIEW_REQUESTED";
|
11850
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["FIRM_INVITE_TO_REGISTER"] = 3000] = "FIRM_INVITE_TO_REGISTER";
|
11851
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["FIRM_INVITE"] = 3001] = "FIRM_INVITE";
|
11852
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["CLIENT_INVITE_ACCEPTED"] = 3002] = "CLIENT_INVITE_ACCEPTED";
|
11853
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["CLIENT_INVITE_REJECTED"] = 3003] = "CLIENT_INVITE_REJECTED";
|
11854
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["CLIENT_INVITE_REGISTERED"] = 3004] = "CLIENT_INVITE_REGISTERED";
|
11855
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["FIRM_NEW_CLIENT"] = 3005] = "FIRM_NEW_CLIENT";
|
11856
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["FIRM_LOST_CLIENT"] = 3006] = "FIRM_LOST_CLIENT";
|
11857
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["EMPLOYEE_INVITE"] = 3010] = "EMPLOYEE_INVITE";
|
11858
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["EMPLOYEE_LOST_CLIENT"] = 3011] = "EMPLOYEE_LOST_CLIENT";
|
11859
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["EMPLOYEE_NEW_CLIENT"] = 3012] = "EMPLOYEE_NEW_CLIENT";
|
11860
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["EMPLOYEE_INVITE_ACCEPTED"] = 3013] = "EMPLOYEE_INVITE_ACCEPTED";
|
11861
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["EMPLOYEE_EMAIL_CONFIRMED"] = 3020] = "EMPLOYEE_EMAIL_CONFIRMED";
|
11862
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["TAX_REVIEW_RECEIVED"] = 3030] = "TAX_REVIEW_RECEIVED";
|
11863
|
-
UserEventTypeTypeEnum[UserEventTypeTypeEnum["SHARESIGHT_IMPORT"] = 2070] = "SHARESIGHT_IMPORT";
|
11864
|
-
})(UserEventTypeTypeEnum || (UserEventTypeTypeEnum = {}));
|
11865
|
-
|
11866
11896
|
/**
|
11867
11897
|
* Service for bank transactions business logic
|
11868
11898
|
*/
|
@@ -12908,6 +12938,7 @@ class ClientMovementService extends RestService$1 {
|
|
12908
12938
|
this.collectionClass = ClientMovementCollection;
|
12909
12939
|
this.modelClass = ClientMovement;
|
12910
12940
|
this.disabledMethods = ['postBatch', 'delete', 'deleteBatch'];
|
12941
|
+
this.mercureTopic = 'clientMovements';
|
12911
12942
|
this.listenEvents();
|
12912
12943
|
}
|
12913
12944
|
listenEvents() {
|
@@ -12915,7 +12946,8 @@ class ClientMovementService extends RestService$1 {
|
|
12915
12946
|
this.eventDispatcherService.on([AppEventTypeEnum.CLIENT_INVITE_ACCEPTED]).subscribe(() => {
|
12916
12947
|
this.refreshCache();
|
12917
12948
|
});
|
12918
|
-
|
12949
|
+
// @TODO remove when TT-3826 is ready
|
12950
|
+
this.listenSSE();
|
12919
12951
|
}
|
12920
12952
|
getActive() {
|
12921
12953
|
return this.get().pipe(map((clientMovements) => clientMovements.active));
|
@@ -12963,21 +12995,6 @@ class ClientMovementService extends RestService$1 {
|
|
12963
12995
|
// this.updateCache([clientMovement], 'delete');
|
12964
12996
|
}));
|
12965
12997
|
}
|
12966
|
-
listenNotifications() {
|
12967
|
-
this.eventDispatcherService.on(AppEventTypeEnum.NOTIFICATION_ADDED).subscribe((notification) => {
|
12968
|
-
const events = [
|
12969
|
-
UserEventTypeTypeEnum.FIRM_INVITE_ACCEPTED,
|
12970
|
-
UserEventTypeTypeEnum.FIRM_INVITE_REJECTED,
|
12971
|
-
UserEventTypeTypeEnum.CLIENT_INVITE_ACCEPTED,
|
12972
|
-
UserEventTypeTypeEnum.CLIENT_INVITE_REJECTED,
|
12973
|
-
UserEventTypeTypeEnum.CLIENT_INVITE_REGISTERED,
|
12974
|
-
];
|
12975
|
-
if (!notification.isRead && events.includes(notification.eventType)) {
|
12976
|
-
// @TODO TT-3826 move to unified mercure event
|
12977
|
-
this.refreshCache();
|
12978
|
-
}
|
12979
|
-
});
|
12980
|
-
}
|
12981
12998
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ClientMovementService, deps: [{ token: 'environment' }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
12982
12999
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ClientMovementService, providedIn: 'root' }); }
|
12983
13000
|
}
|
@@ -16436,15 +16453,15 @@ class HoldingTypeService extends RestService$1 {
|
|
16436
16453
|
this.endpointUri = 'holding-types';
|
16437
16454
|
this.disabledMethods = ['postBatch', 'putBatch', 'deleteBatch'];
|
16438
16455
|
this.roles = [UserRolesEnum.HOLDING_TANK];
|
16439
|
-
|
16456
|
+
this.listenEvents();
|
16457
|
+
}
|
16458
|
+
search(query, category = null) {
|
16459
|
+
query = query.toLowerCase().trim();
|
16460
|
+
return this.fetch(`${this.apiUrl}`, false, { params: { query, category } });
|
16461
|
+
}
|
16462
|
+
getCurrent() {
|
16463
|
+
return this.get(`${this.apiUrl}/current`);
|
16440
16464
|
}
|
16441
|
-
// search(searchQuery: string, category: HoldingTypeCategoryEnum = null): Observable<HoldingType[]> {
|
16442
|
-
// searchQuery = searchQuery.toLowerCase().trim();
|
16443
|
-
//
|
16444
|
-
// return this.http.get(`${this.apiUrl}`, { params: { searchQuery, category } }).pipe(
|
16445
|
-
// map((userBase: UserBase) => this.createModelInstance(userBase))
|
16446
|
-
// );
|
16447
|
-
// }
|
16448
16465
|
listenEvents() {
|
16449
16466
|
this.listenCSE(BankTransaction, (trade) => this.hasInCache(trade.holdingType.id) ? this.updateCache([trade.holdingType], 'post') : '', ['post']);
|
16450
16467
|
}
|
@@ -19873,15 +19890,8 @@ class XlsxService {
|
|
19873
19890
|
// add caption for the current table
|
19874
19891
|
xlsx.utils.sheet_add_aoa(worksheet, [[data.caption?.innerText]], { origin: -1 });
|
19875
19892
|
// Prepare to add table data to the worksheet, processing each cell
|
19876
|
-
const rows = Array.from(data.rows)
|
19877
|
-
|
19878
|
-
// Convert currency strings like "$0.00" to numbers
|
19879
|
-
if (/^-?\$/.test(cellValue)) {
|
19880
|
-
// @TODO vik fix
|
19881
|
-
// cellValue = parseFloat(cellValue.replace('$', ''));
|
19882
|
-
}
|
19883
|
-
return cellValue;
|
19884
|
-
}));
|
19893
|
+
const rows = Array.from(data.rows)
|
19894
|
+
.map((row) => Array.from(row.cells).map(cell => this.htmlToXlsCell(cell)));
|
19885
19895
|
// Add the processed table data to the worksheet
|
19886
19896
|
xlsx.utils.sheet_add_aoa(worksheet, rows, { origin: -1 });
|
19887
19897
|
// set empty row after current table
|
@@ -19890,6 +19900,21 @@ class XlsxService {
|
|
19890
19900
|
xlsx.utils.book_append_sheet(workbook, worksheet);
|
19891
19901
|
return xlsx.write(workbook, { bookType: 'xlsx', type: 'array' });
|
19892
19902
|
}
|
19903
|
+
htmlToXlsCell(cell) {
|
19904
|
+
const cellValue = cell.innerText;
|
19905
|
+
// regex to check currency value
|
19906
|
+
return /^-?\$/.test(cellValue) ? this.currencyToNumber(cellValue) : cellValue;
|
19907
|
+
}
|
19908
|
+
/**
|
19909
|
+
* function which reconverts values from customCurrencyPipe
|
19910
|
+
* @param cellValue - string with $ and possibly comma. $123,123.03
|
19911
|
+
* @returns value without $ and comma. like 123123.03
|
19912
|
+
*/
|
19913
|
+
currencyToNumber(cellValue) {
|
19914
|
+
// remove dollar sign and comma
|
19915
|
+
cellValue = cellValue.replace(/[$,]/g, '');
|
19916
|
+
return parseFloat(cellValue);
|
19917
|
+
}
|
19893
19918
|
/**
|
19894
19919
|
* @TODO vik/artem work with ExportDataTable instead of ExportableCollection
|
19895
19920
|
* @TODO vik/artem why so much code? here is 6 rows solution https://stackoverflow.com/questions/64939994/how-to-export-array-of-objects-to-an-excel-in-angular-8
|