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.
@@ -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).map((row) => Array.from(row.cells).map((cell) => {
43
- const cellValue = cell.innerText;
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":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,KAAK,SAAS,MAAM,YAAY,CAAC;;AAIxC,MAAM,UAAU,GAAW,iFAAiF,CAAA;AAM5G;;GAEG;AACH,MAAM,OAAO,WAAW;IAPxB;QA+DE,gBAAW,GAAG,CAAC,IAAY,EAAE,EAAE;YAC7B,MAAM,SAAS,GAAG,IAAI,IAAI,cAAc,CAAC;YACzC,MAAM,QAAQ,GAAG,GAAG,SAAS,EAAE,CAAC;YAChC,OAAO;gBACL,SAAS;gBACT,QAAQ;aACT,CAAC;QACJ,CAAC,CAAC;KAgCH;IA9FC;;OAEG;IACH,YAAY,CAAC,MAAoC,EAAE,KAAa,EAAE,QAAgB;QAChF,MAAM,SAAS,GAAa,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QACnE,MAAM,IAAI,GAAS,IAAI,IAAI,CAAC,CAAC,SAAS,CAAC,EAAE;YACvC,IAAI,EAAE,UAAU;SACjB,CAAC,CAAC;QAEH,SAAS,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,QAAQ,OAAO,CAAC,CAAC;IAC7C,CAAC;IAEO,kBAAkB,CAAC,MAAoC,EAAE,KAAc;QAC7E,sBAAsB;QACtB,MAAM,QAAQ,GAAkB,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;QACtD,yBAAyB;QACzB,MAAM,SAAS,GAAmB;YAChC,UAAU,EAAE,EAAE;YACd,MAAM,EAAE,EAAE;SACX,CAAC;QAEF,MAAM,CAAC,OAAO,CAAC,CAAC,IAAsB,EAAE,EAAE;YACxC,oCAAoC;YACpC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;YACjF,mEAAmE;YACnE,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;iBAC/B,GAAG,CAAC,CAAC,GAAwB,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAClG,gDAAgD;YAChD,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,SAAS,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;YAC1D,oCAAoC;YACpC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,SAAS,EAAE,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;QAC1D,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;QAClD,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC;IACnE,CAAC;IAED,aAAa,CAAC,IAA0B;QACtC,MAAM,SAAS,GAAoB,IAAI,CAAC,SAAS,CAAC;QAClD,gCAAgC;QAChC,OAAO,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IAChF,CAAC;IAED;;;;OAIG;IACH,gBAAgB,CAAC,SAAiB;QAChC,+BAA+B;QAC/B,SAAS,GAAG,SAAS,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QAE3C,OAAO,UAAU,CAAC,SAAS,CAAC,CAAC;IAC/B,CAAC;IAWD;;;OAGG;IACH,kBAAkB,CAAC,oBAA+C,EAAE,IAAa,EAAE,MAAa;QAC9F,MAAM,QAAQ,GAAkB,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;QACtD,yBAAyB;QACzB,MAAM,SAAS,GAAmB;YAChC,UAAU,EAAE,EAAE;YACd,MAAM,EAAE,EAAE;SACX,CAAC;QAEF,MAAM,UAAU,GAAoB,oBAAoB,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;QACvE,MAAM,SAAS,GAAG,oBAAoB,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;QAC9D,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAEvD,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;QACzE,wCAAwC;QACxC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,SAAS,EAAE,SAAS,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;QAC/D,oCAAoC;QACpC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,SAAS,EAAE,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;QAExD,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;QAClD,MAAM,SAAS,GAAa,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC;QAEtF,MAAM,IAAI,GAAS,IAAI,IAAI,CAAC,CAAC,SAAS,CAAC,EAAE;YACvC,IAAI,EAAE,UAAU;SACjB,CAAC,CAAC;QACH,SAAS,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,QAAQ,OAAO,CAAC,CAAC;IAC7C,CAAC;+GA9FU,WAAW;mHAAX,WAAW,cANV,MAAM;;4FAMP,WAAW;kBAPvB,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","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, items) {
11283
- return new collectionClass(items);
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.map((item) => this.createModelInstance(item)));
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
- // Set cache as empty collection to avoid multiple requests before cache filled
11393
- this.setCache([]);
11394
- return this.http.get(path)
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
- this.setCache(response, true);
11397
- return this.cache;
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
- cache = this.createCollectionInstance(this.collectionClass, items);
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.listenConnections();
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
- // @TODO remove when TT-3826 is ready
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
- this.listenNotifications();
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
- // this.listenEvents();
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).map((row) => Array.from(row.cells).map((cell) => {
19877
- const cellValue = cell.innerText;
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