@veloceapps/api 2.0.15 → 2.0.17

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.
@@ -6,10 +6,11 @@ export class DocumentAttachmentApiService {
6
6
  constructor(httpService, fileDownloadService) {
7
7
  this.httpService = httpService;
8
8
  this.fileDownloadService = fileDownloadService;
9
+ this.SERVICE_URL = '/attachments';
9
10
  }
10
11
  getAttachments(searchRequest) {
11
12
  return this.httpService.api({
12
- url: '/attachments/search',
13
+ url: `${this.SERVICE_URL}/search`,
13
14
  method: 'post',
14
15
  body: searchRequest,
15
16
  });
@@ -23,7 +24,7 @@ export class DocumentAttachmentApiService {
23
24
  type: 'application/json',
24
25
  }));
25
26
  return this.httpService.upload({
26
- url: `/attachments`,
27
+ url: `${this.SERVICE_URL}`,
27
28
  body: formData,
28
29
  method: 'post',
29
30
  observe: reportProgress ? 'events' : undefined,
@@ -32,7 +33,7 @@ export class DocumentAttachmentApiService {
32
33
  }
33
34
  updateAttachment(id, attachment) {
34
35
  return this.httpService.api({
35
- url: `/attachments/${id}`,
36
+ url: `${this.SERVICE_URL}/${id}`,
36
37
  body: attachment,
37
38
  method: 'put',
38
39
  });
@@ -40,7 +41,7 @@ export class DocumentAttachmentApiService {
40
41
  getAttachmentFile(id, isPreventDownload) {
41
42
  return this.httpService
42
43
  .api({
43
- url: `/attachments/${id}/file`,
44
+ url: `${this.SERVICE_URL}/${id}/file`,
44
45
  responseType: isPreventDownload ? 'arraybuffer' : 'blob',
45
46
  observe: isPreventDownload ? 'body' : 'response',
46
47
  })
@@ -52,7 +53,7 @@ export class DocumentAttachmentApiService {
52
53
  }
53
54
  removeAttachment(id) {
54
55
  return this.httpService.api({
55
- url: `/attachments/${id}`,
56
+ url: `${this.SERVICE_URL}/${id}`,
56
57
  method: 'delete',
57
58
  });
58
59
  }
@@ -62,4 +63,4 @@ DocumentAttachmentApiService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "
62
63
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: DocumentAttachmentApiService, decorators: [{
63
64
  type: Injectable
64
65
  }], ctorParameters: function () { return [{ type: i1.BaseHttpService }, { type: i1.FileDownloadService }]; } });
65
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9jdW1lbnQtYXR0YWNobWVudC1hcGkuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYXBpL3NyYy9saWIvc2VydmljZXMvZG9jdW1lbnQtYXR0YWNobWVudC1hcGkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBUTNDLE9BQU8sRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQUcxQyxNQUFNLE9BQU8sNEJBQTRCO0lBQ3ZDLFlBQW9CLFdBQTRCLEVBQVUsbUJBQXdDO1FBQTlFLGdCQUFXLEdBQVgsV0FBVyxDQUFpQjtRQUFVLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBcUI7SUFBRyxDQUFDO0lBRXRHLGNBQWMsQ0FBQyxhQUE4QztRQUMzRCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDO1lBQzFCLEdBQUcsRUFBRSxxQkFBcUI7WUFDMUIsTUFBTSxFQUFFLE1BQU07WUFDZCxJQUFJLEVBQUUsYUFBYTtTQUNwQixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsZ0JBQWdCLENBQ2QsVUFBOEIsRUFDOUIsSUFBVyxFQUNYLGNBQXdCO1FBRXhCLE1BQU0sUUFBUSxHQUFhLElBQUksUUFBUSxFQUFFLENBQUM7UUFFMUMsSUFBSSxJQUFJLEVBQUU7WUFDUixRQUFRLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQzFDO1FBRUQsUUFBUSxDQUFDLE1BQU0sQ0FDYixZQUFZLEVBQ1osSUFBSSxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxDQUFDLEVBQUU7WUFDckMsSUFBSSxFQUFFLGtCQUFrQjtTQUN6QixDQUFDLENBQ0gsQ0FBQztRQUVGLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUM7WUFDN0IsR0FBRyxFQUFFLGNBQWM7WUFDbkIsSUFBSSxFQUFFLFFBQVE7WUFDZCxNQUFNLEVBQUUsTUFBTTtZQUNkLE9BQU8sRUFBRSxjQUFjLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsU0FBUztZQUM5QyxjQUFjO1NBQ2YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELGdCQUFnQixDQUFDLEVBQVUsRUFBRSxVQUE4QjtRQUN6RCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDO1lBQzFCLEdBQUcsRUFBRSxnQkFBZ0IsRUFBRSxFQUFFO1lBQ3pCLElBQUksRUFBRSxVQUFVO1lBQ2hCLE1BQU0sRUFBRSxLQUFLO1NBQ2QsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQVUsRUFBRSxpQkFBMkI7UUFDdkQsT0FBTyxJQUFJLENBQUMsV0FBVzthQUNwQixHQUFHLENBQUM7WUFDSCxHQUFHLEVBQUUsZ0JBQWdCLEVBQUUsT0FBTztZQUM5QixZQUFZLEVBQUUsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsTUFBTTtZQUN4RCxPQUFPLEVBQUUsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsVUFBVTtTQUNqRCxDQUFDO2FBQ0QsSUFBSSxDQUNILEdBQUcsQ0FBQyxRQUFRLENBQUMsRUFBRTtZQUNiLElBQUksQ0FBQyxpQkFBaUIsRUFBRTtnQkFDdEIsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGVBQWUsQ0FBQyxRQUFRLENBQUMsQ0FBQzthQUNwRDtRQUNILENBQUMsQ0FBQyxFQUNGLEdBQUcsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLElBQUksSUFBSSxDQUFDLENBQUMsUUFBUSxDQUFDLElBQUksSUFBSSxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsSUFBSSxJQUFJLFFBQVEsQ0FBQyxDQUFDLENBQ3pHLENBQUM7SUFDTixDQUFDO0lBRUQsZ0JBQWdCLENBQUMsRUFBVTtRQUN6QixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDO1lBQzFCLEdBQUcsRUFBRSxnQkFBZ0IsRUFBRSxFQUFFO1lBQ3pCLE1BQU0sRUFBRSxRQUFRO1NBQ2pCLENBQUMsQ0FBQztJQUNMLENBQUM7OzBIQXBFVSw0QkFBNEI7OEhBQTVCLDRCQUE0Qjs0RkFBNUIsNEJBQTRCO2tCQUR4QyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgQmFzZUh0dHBTZXJ2aWNlLFxuICBGaWxlRG93bmxvYWRTZXJ2aWNlLFxuICBUZW1wbGF0ZUF0dGFjaG1lbnQsXG4gIFRlbXBsYXRlQXR0YWNobWVudFNlYXJjaFJlcXVlc3QsXG59IGZyb20gJ0B2ZWxvY2UvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBtYXAsIHRhcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIERvY3VtZW50QXR0YWNobWVudEFwaVNlcnZpY2Uge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGh0dHBTZXJ2aWNlOiBCYXNlSHR0cFNlcnZpY2UsIHByaXZhdGUgZmlsZURvd25sb2FkU2VydmljZTogRmlsZURvd25sb2FkU2VydmljZSkge31cblxuICBnZXRBdHRhY2htZW50cyhzZWFyY2hSZXF1ZXN0OiBUZW1wbGF0ZUF0dGFjaG1lbnRTZWFyY2hSZXF1ZXN0KTogT2JzZXJ2YWJsZTxUZW1wbGF0ZUF0dGFjaG1lbnRbXT4ge1xuICAgIHJldHVybiB0aGlzLmh0dHBTZXJ2aWNlLmFwaSh7XG4gICAgICB1cmw6ICcvYXR0YWNobWVudHMvc2VhcmNoJyxcbiAgICAgIG1ldGhvZDogJ3Bvc3QnLFxuICAgICAgYm9keTogc2VhcmNoUmVxdWVzdCxcbiAgICB9KTtcbiAgfVxuXG4gIGNyZWF0ZUF0dGFjaG1lbnQoXG4gICAgYXR0YWNobWVudDogVGVtcGxhdGVBdHRhY2htZW50LFxuICAgIGZpbGU/OiBGaWxlLFxuICAgIHJlcG9ydFByb2dyZXNzPzogYm9vbGVhbixcbiAgKTogT2JzZXJ2YWJsZTxUZW1wbGF0ZUF0dGFjaG1lbnQ+IHtcbiAgICBjb25zdCBmb3JtRGF0YTogRm9ybURhdGEgPSBuZXcgRm9ybURhdGEoKTtcblxuICAgIGlmIChmaWxlKSB7XG4gICAgICBmb3JtRGF0YS5hcHBlbmQoJ2ZpbGUnLCBmaWxlLCBmaWxlLm5hbWUpO1xuICAgIH1cblxuICAgIGZvcm1EYXRhLmFwcGVuZChcbiAgICAgICdhdHRhY2htZW50JyxcbiAgICAgIG5ldyBCbG9iKFtKU09OLnN0cmluZ2lmeShhdHRhY2htZW50KV0sIHtcbiAgICAgICAgdHlwZTogJ2FwcGxpY2F0aW9uL2pzb24nLFxuICAgICAgfSksXG4gICAgKTtcblxuICAgIHJldHVybiB0aGlzLmh0dHBTZXJ2aWNlLnVwbG9hZCh7XG4gICAgICB1cmw6IGAvYXR0YWNobWVudHNgLFxuICAgICAgYm9keTogZm9ybURhdGEsXG4gICAgICBtZXRob2Q6ICdwb3N0JyxcbiAgICAgIG9ic2VydmU6IHJlcG9ydFByb2dyZXNzID8gJ2V2ZW50cycgOiB1bmRlZmluZWQsXG4gICAgICByZXBvcnRQcm9ncmVzcyxcbiAgICB9KTtcbiAgfVxuXG4gIHVwZGF0ZUF0dGFjaG1lbnQoaWQ6IHN0cmluZywgYXR0YWNobWVudDogVGVtcGxhdGVBdHRhY2htZW50KTogT2JzZXJ2YWJsZTxUZW1wbGF0ZUF0dGFjaG1lbnQ+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwU2VydmljZS5hcGkoe1xuICAgICAgdXJsOiBgL2F0dGFjaG1lbnRzLyR7aWR9YCxcbiAgICAgIGJvZHk6IGF0dGFjaG1lbnQsXG4gICAgICBtZXRob2Q6ICdwdXQnLFxuICAgIH0pO1xuICB9XG5cbiAgZ2V0QXR0YWNobWVudEZpbGUoaWQ6IHN0cmluZywgaXNQcmV2ZW50RG93bmxvYWQ/OiBib29sZWFuKTogT2JzZXJ2YWJsZTxhbnk+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwU2VydmljZVxuICAgICAgLmFwaSh7XG4gICAgICAgIHVybDogYC9hdHRhY2htZW50cy8ke2lkfS9maWxlYCxcbiAgICAgICAgcmVzcG9uc2VUeXBlOiBpc1ByZXZlbnREb3dubG9hZCA/ICdhcnJheWJ1ZmZlcicgOiAnYmxvYicsXG4gICAgICAgIG9ic2VydmU6IGlzUHJldmVudERvd25sb2FkID8gJ2JvZHknIDogJ3Jlc3BvbnNlJyxcbiAgICAgIH0pXG4gICAgICAucGlwZShcbiAgICAgICAgdGFwKHJlc3BvbnNlID0+IHtcbiAgICAgICAgICBpZiAoIWlzUHJldmVudERvd25sb2FkKSB7XG4gICAgICAgICAgICB0aGlzLmZpbGVEb3dubG9hZFNlcnZpY2UucHJvY2Vzc0Rvd25sb2FkKHJlc3BvbnNlKTtcbiAgICAgICAgICB9XG4gICAgICAgIH0pLFxuICAgICAgICBtYXAocmVzcG9uc2UgPT4gKGlzUHJldmVudERvd25sb2FkID8gbmV3IEJsb2IoW3Jlc3BvbnNlLmJvZHkgfHwgcmVzcG9uc2VdKSA6IHJlc3BvbnNlLmJvZHkgfHwgcmVzcG9uc2UpKSxcbiAgICAgICk7XG4gIH1cblxuICByZW1vdmVBdHRhY2htZW50KGlkOiBzdHJpbmcpOiBPYnNlcnZhYmxlPHVua25vd24+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwU2VydmljZS5hcGkoe1xuICAgICAgdXJsOiBgL2F0dGFjaG1lbnRzLyR7aWR9YCxcbiAgICAgIG1ldGhvZDogJ2RlbGV0ZScsXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9jdW1lbnQtYXR0YWNobWVudC1hcGkuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYXBpL3NyYy9saWIvc2VydmljZXMvZG9jdW1lbnQtYXR0YWNobWVudC1hcGkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBUTNDLE9BQU8sRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQUcxQyxNQUFNLE9BQU8sNEJBQTRCO0lBR3ZDLFlBQW9CLFdBQTRCLEVBQVUsbUJBQXdDO1FBQTlFLGdCQUFXLEdBQVgsV0FBVyxDQUFpQjtRQUFVLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBcUI7UUFGakYsZ0JBQVcsR0FBRyxjQUFjLENBQUM7SUFFdUQsQ0FBQztJQUV0RyxjQUFjLENBQUMsYUFBOEM7UUFDM0QsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQztZQUMxQixHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsV0FBVyxTQUFTO1lBQ2pDLE1BQU0sRUFBRSxNQUFNO1lBQ2QsSUFBSSxFQUFFLGFBQWE7U0FDcEIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELGdCQUFnQixDQUNkLFVBQThCLEVBQzlCLElBQVcsRUFDWCxjQUF3QjtRQUV4QixNQUFNLFFBQVEsR0FBYSxJQUFJLFFBQVEsRUFBRSxDQUFDO1FBRTFDLElBQUksSUFBSSxFQUFFO1lBQ1IsUUFBUSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUMxQztRQUVELFFBQVEsQ0FBQyxNQUFNLENBQ2IsWUFBWSxFQUNaLElBQUksSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxFQUFFO1lBQ3JDLElBQUksRUFBRSxrQkFBa0I7U0FDekIsQ0FBQyxDQUNILENBQUM7UUFFRixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDO1lBQzdCLEdBQUcsRUFBRSxHQUFHLElBQUksQ0FBQyxXQUFXLEVBQUU7WUFDMUIsSUFBSSxFQUFFLFFBQVE7WUFDZCxNQUFNLEVBQUUsTUFBTTtZQUNkLE9BQU8sRUFBRSxjQUFjLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsU0FBUztZQUM5QyxjQUFjO1NBQ2YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELGdCQUFnQixDQUFDLEVBQVUsRUFBRSxVQUE4QjtRQUN6RCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDO1lBQzFCLEdBQUcsRUFBRSxHQUFHLElBQUksQ0FBQyxXQUFXLElBQUksRUFBRSxFQUFFO1lBQ2hDLElBQUksRUFBRSxVQUFVO1lBQ2hCLE1BQU0sRUFBRSxLQUFLO1NBQ2QsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQVUsRUFBRSxpQkFBMkI7UUFDdkQsT0FBTyxJQUFJLENBQUMsV0FBVzthQUNwQixHQUFHLENBQUM7WUFDSCxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsV0FBVyxJQUFJLEVBQUUsT0FBTztZQUNyQyxZQUFZLEVBQUUsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsTUFBTTtZQUN4RCxPQUFPLEVBQUUsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsVUFBVTtTQUNqRCxDQUFDO2FBQ0QsSUFBSSxDQUNILEdBQUcsQ0FBQyxRQUFRLENBQUMsRUFBRTtZQUNiLElBQUksQ0FBQyxpQkFBaUIsRUFBRTtnQkFDdEIsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGVBQWUsQ0FBQyxRQUFRLENBQUMsQ0FBQzthQUNwRDtRQUNILENBQUMsQ0FBQyxFQUNGLEdBQUcsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLElBQUksSUFBSSxDQUFDLENBQUMsUUFBUSxDQUFDLElBQUksSUFBSSxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsSUFBSSxJQUFJLFFBQVEsQ0FBQyxDQUFDLENBQ3pHLENBQUM7SUFDTixDQUFDO0lBRUQsZ0JBQWdCLENBQUMsRUFBVTtRQUN6QixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDO1lBQzFCLEdBQUcsRUFBRSxHQUFHLElBQUksQ0FBQyxXQUFXLElBQUksRUFBRSxFQUFFO1lBQ2hDLE1BQU0sRUFBRSxRQUFRO1NBQ2pCLENBQUMsQ0FBQztJQUNMLENBQUM7OzBIQXRFVSw0QkFBNEI7OEhBQTVCLDRCQUE0Qjs0RkFBNUIsNEJBQTRCO2tCQUR4QyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgQmFzZUh0dHBTZXJ2aWNlLFxuICBGaWxlRG93bmxvYWRTZXJ2aWNlLFxuICBUZW1wbGF0ZUF0dGFjaG1lbnQsXG4gIFRlbXBsYXRlQXR0YWNobWVudFNlYXJjaFJlcXVlc3QsXG59IGZyb20gJ0B2ZWxvY2UvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBtYXAsIHRhcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIERvY3VtZW50QXR0YWNobWVudEFwaVNlcnZpY2Uge1xuICBwcml2YXRlIHJlYWRvbmx5IFNFUlZJQ0VfVVJMID0gJy9hdHRhY2htZW50cyc7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBodHRwU2VydmljZTogQmFzZUh0dHBTZXJ2aWNlLCBwcml2YXRlIGZpbGVEb3dubG9hZFNlcnZpY2U6IEZpbGVEb3dubG9hZFNlcnZpY2UpIHt9XG5cbiAgZ2V0QXR0YWNobWVudHMoc2VhcmNoUmVxdWVzdDogVGVtcGxhdGVBdHRhY2htZW50U2VhcmNoUmVxdWVzdCk6IE9ic2VydmFibGU8VGVtcGxhdGVBdHRhY2htZW50W10+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwU2VydmljZS5hcGkoe1xuICAgICAgdXJsOiBgJHt0aGlzLlNFUlZJQ0VfVVJMfS9zZWFyY2hgLFxuICAgICAgbWV0aG9kOiAncG9zdCcsXG4gICAgICBib2R5OiBzZWFyY2hSZXF1ZXN0LFxuICAgIH0pO1xuICB9XG5cbiAgY3JlYXRlQXR0YWNobWVudChcbiAgICBhdHRhY2htZW50OiBUZW1wbGF0ZUF0dGFjaG1lbnQsXG4gICAgZmlsZT86IEZpbGUsXG4gICAgcmVwb3J0UHJvZ3Jlc3M/OiBib29sZWFuLFxuICApOiBPYnNlcnZhYmxlPFRlbXBsYXRlQXR0YWNobWVudD4ge1xuICAgIGNvbnN0IGZvcm1EYXRhOiBGb3JtRGF0YSA9IG5ldyBGb3JtRGF0YSgpO1xuXG4gICAgaWYgKGZpbGUpIHtcbiAgICAgIGZvcm1EYXRhLmFwcGVuZCgnZmlsZScsIGZpbGUsIGZpbGUubmFtZSk7XG4gICAgfVxuXG4gICAgZm9ybURhdGEuYXBwZW5kKFxuICAgICAgJ2F0dGFjaG1lbnQnLFxuICAgICAgbmV3IEJsb2IoW0pTT04uc3RyaW5naWZ5KGF0dGFjaG1lbnQpXSwge1xuICAgICAgICB0eXBlOiAnYXBwbGljYXRpb24vanNvbicsXG4gICAgICB9KSxcbiAgICApO1xuXG4gICAgcmV0dXJuIHRoaXMuaHR0cFNlcnZpY2UudXBsb2FkKHtcbiAgICAgIHVybDogYCR7dGhpcy5TRVJWSUNFX1VSTH1gLFxuICAgICAgYm9keTogZm9ybURhdGEsXG4gICAgICBtZXRob2Q6ICdwb3N0JyxcbiAgICAgIG9ic2VydmU6IHJlcG9ydFByb2dyZXNzID8gJ2V2ZW50cycgOiB1bmRlZmluZWQsXG4gICAgICByZXBvcnRQcm9ncmVzcyxcbiAgICB9KTtcbiAgfVxuXG4gIHVwZGF0ZUF0dGFjaG1lbnQoaWQ6IHN0cmluZywgYXR0YWNobWVudDogVGVtcGxhdGVBdHRhY2htZW50KTogT2JzZXJ2YWJsZTxUZW1wbGF0ZUF0dGFjaG1lbnQ+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwU2VydmljZS5hcGkoe1xuICAgICAgdXJsOiBgJHt0aGlzLlNFUlZJQ0VfVVJMfS8ke2lkfWAsXG4gICAgICBib2R5OiBhdHRhY2htZW50LFxuICAgICAgbWV0aG9kOiAncHV0JyxcbiAgICB9KTtcbiAgfVxuXG4gIGdldEF0dGFjaG1lbnRGaWxlKGlkOiBzdHJpbmcsIGlzUHJldmVudERvd25sb2FkPzogYm9vbGVhbik6IE9ic2VydmFibGU8YW55PiB7XG4gICAgcmV0dXJuIHRoaXMuaHR0cFNlcnZpY2VcbiAgICAgIC5hcGkoe1xuICAgICAgICB1cmw6IGAke3RoaXMuU0VSVklDRV9VUkx9LyR7aWR9L2ZpbGVgLFxuICAgICAgICByZXNwb25zZVR5cGU6IGlzUHJldmVudERvd25sb2FkID8gJ2FycmF5YnVmZmVyJyA6ICdibG9iJyxcbiAgICAgICAgb2JzZXJ2ZTogaXNQcmV2ZW50RG93bmxvYWQgPyAnYm9keScgOiAncmVzcG9uc2UnLFxuICAgICAgfSlcbiAgICAgIC5waXBlKFxuICAgICAgICB0YXAocmVzcG9uc2UgPT4ge1xuICAgICAgICAgIGlmICghaXNQcmV2ZW50RG93bmxvYWQpIHtcbiAgICAgICAgICAgIHRoaXMuZmlsZURvd25sb2FkU2VydmljZS5wcm9jZXNzRG93bmxvYWQocmVzcG9uc2UpO1xuICAgICAgICAgIH1cbiAgICAgICAgfSksXG4gICAgICAgIG1hcChyZXNwb25zZSA9PiAoaXNQcmV2ZW50RG93bmxvYWQgPyBuZXcgQmxvYihbcmVzcG9uc2UuYm9keSB8fCByZXNwb25zZV0pIDogcmVzcG9uc2UuYm9keSB8fCByZXNwb25zZSkpLFxuICAgICAgKTtcbiAgfVxuXG4gIHJlbW92ZUF0dGFjaG1lbnQoaWQ6IHN0cmluZyk6IE9ic2VydmFibGU8dW5rbm93bj4ge1xuICAgIHJldHVybiB0aGlzLmh0dHBTZXJ2aWNlLmFwaSh7XG4gICAgICB1cmw6IGAke3RoaXMuU0VSVklDRV9VUkx9LyR7aWR9YCxcbiAgICAgIG1ldGhvZDogJ2RlbGV0ZScsXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
@@ -1,6 +1,6 @@
1
1
  import { CurrencyPipe } from '@angular/common';
2
2
  import { Injectable } from '@angular/core';
3
- import { DocxTemplater, QuoteDraft, StringUtils, } from '@veloce/core';
3
+ import { DocxTemplater, isLegacyDocumentTemplate, QuoteDraft, StringUtils, } from '@veloce/core';
4
4
  import * as _ from 'lodash';
5
5
  import * as moment_ from 'moment';
6
6
  import { forkJoin, of, zip } from 'rxjs';
@@ -9,49 +9,58 @@ import * as i0 from "@angular/core";
9
9
  import * as i1 from "@veloce/core";
10
10
  import * as i2 from "./salesforce-api.service";
11
11
  import * as i3 from "./document-attachment-api.service";
12
- import * as i4 from "@angular/common/http";
12
+ import * as i4 from "./quote-api.service";
13
+ import * as i5 from "@angular/common/http";
13
14
  const moment = moment_;
14
- const mapSfQueryResult = (limit) => map((records) => {
15
- if (!records.length) {
16
- return { _result: 'No Records Found' };
17
- }
18
- if (limit === 1) {
19
- return records[0];
20
- }
21
- return records;
22
- });
23
- const mapBooleanIfAplicable = (value) => {
24
- if (value === 'true') {
25
- return true;
26
- }
27
- if (value === 'false') {
28
- return false;
29
- }
30
- return value;
31
- };
32
15
  export class DocumentTemplatesApiService {
33
- constructor(service, sfRepo, fileDownloadService, documentAttachmentService, http) {
16
+ constructor(service, salesforceApiService, fileDownloadService, documentAttachmentService, quoteApiService, http) {
34
17
  this.service = service;
35
- this.sfRepo = sfRepo;
18
+ this.salesforceApiService = salesforceApiService;
36
19
  this.fileDownloadService = fileDownloadService;
37
20
  this.documentAttachmentService = documentAttachmentService;
21
+ this.quoteApiService = quoteApiService;
38
22
  this.http = http;
39
- this.fallbackDocGenHost = 'https://dev-dp1.velocpq.com/docgen';
23
+ this.SERVICE_URL = '/templates';
24
+ this.DOC_GEN_URL_FALLBACK = 'https://dev-dp1.velocpq.com/docgen';
25
+ this.mapSfQueryResult = (limit) => map((records) => {
26
+ if (!records.length) {
27
+ return { _result: 'No Records Found' };
28
+ }
29
+ if (limit === 1) {
30
+ return records[0];
31
+ }
32
+ return records;
33
+ });
34
+ this.mapBooleanIfAplicable = (value) => {
35
+ if (value === 'true') {
36
+ return true;
37
+ }
38
+ if (value === 'false') {
39
+ return false;
40
+ }
41
+ return value;
42
+ };
40
43
  if (window.VELO_DOCGEN_API) {
41
- this.docGenHost = window.VELO_DOCGEN_API;
44
+ this.DOC_GEN_URL = window.VELO_DOCGEN_API;
42
45
  }
43
46
  else {
44
- console.log(`window.VELO_DOCGEN_API not set, will use fallback "${this.fallbackDocGenHost}"`);
45
- this.docGenHost = this.fallbackDocGenHost;
47
+ console.log(`window.VELO_DOCGEN_API not set, will use fallback "${this.DOC_GEN_URL_FALLBACK}"`);
48
+ this.DOC_GEN_URL = this.DOC_GEN_URL_FALLBACK;
46
49
  }
47
50
  }
48
51
  getTemplates(tag) {
49
52
  return this.service.api({
50
- url: '/templates',
53
+ url: `${this.SERVICE_URL}`,
51
54
  method: 'get',
52
55
  params: Object.assign({}, (tag && { tag })),
53
56
  });
54
57
  }
58
+ getTemplate(id) {
59
+ return this.service.api({
60
+ url: `${this.SERVICE_URL}/${id}`,
61
+ method: 'get',
62
+ });
63
+ }
55
64
  upsertTemplate(template, file, reportProgress) {
56
65
  const formData = new FormData();
57
66
  if (file) {
@@ -60,8 +69,12 @@ export class DocumentTemplatesApiService {
60
69
  formData.append('template', new Blob([JSON.stringify(template)], {
61
70
  type: 'application/json',
62
71
  }));
72
+ let url = `${this.SERVICE_URL}`;
73
+ if (template.id) {
74
+ url += `/${template.id}`;
75
+ }
63
76
  return this.service.upload({
64
- url: `/templates` + ((template.id && `/${template.id}`) || ''),
77
+ url,
65
78
  body: formData,
66
79
  method: template.id ? 'put' : 'post',
67
80
  reportProgress,
@@ -69,19 +82,19 @@ export class DocumentTemplatesApiService {
69
82
  }
70
83
  removeTemplate(id) {
71
84
  return this.service.api({
72
- url: '/templates/' + id,
85
+ url: `${this.SERVICE_URL}/${id}`,
73
86
  method: 'delete',
74
87
  });
75
88
  }
76
89
  restoreTemplate(id) {
77
90
  return this.service.api({
78
- url: `/templates/${id}/restore`,
91
+ url: `${this.SERVICE_URL}/${id}/restore`,
79
92
  method: 'patch',
80
93
  });
81
94
  }
82
95
  cloneTemplate(id, propertiesToOverride = {}) {
83
96
  return this.service.api({
84
- url: '/templates/clone/' + id,
97
+ url: `${this.SERVICE_URL}/clone/${id}`,
85
98
  method: 'post',
86
99
  body: {
87
100
  id,
@@ -89,15 +102,93 @@ export class DocumentTemplatesApiService {
89
102
  },
90
103
  });
91
104
  }
92
- generateDocumentData(template, object, params) {
93
- var _a, _b, _c, _d;
94
- const shouldPreventDownload = params === null || params === void 0 ? void 0 : params.shouldPreventDownload;
95
- const useLocalDataGeneration = (_b = (_a = template.properties) === null || _a === void 0 ? void 0 : _a.find(({ name }) => name === 'useLocalDataGeneration')) === null || _b === void 0 ? void 0 : _b.value;
96
- if (!useLocalDataGeneration && object instanceof QuoteDraft) {
97
- return this.generate('/templates/generate-data', { template, quote: object }, shouldPreventDownload, shouldPreventDownload ? 'json' : 'blob');
105
+ getTemplateFile(id) {
106
+ return this.service.api({
107
+ method: 'get',
108
+ url: `${this.SERVICE_URL}/${id}/file`,
109
+ responseType: 'arraybuffer',
110
+ });
111
+ }
112
+ downloadTemplateFile(id) {
113
+ return this.service
114
+ .api({
115
+ url: `${this.SERVICE_URL}/${id}/file`,
116
+ responseType: 'blob',
117
+ observe: 'response',
118
+ })
119
+ .pipe(tap(response => {
120
+ this.fileDownloadService.processDownload(response);
121
+ }), map(response => response.body || response));
122
+ }
123
+ mergeDocuments(document, attachments) {
124
+ const body = new FormData();
125
+ attachments.forEach(attachment => {
126
+ body.append('attachments', new Blob([attachment]));
127
+ });
128
+ body.append('orderform', document);
129
+ return this.http.post(`${this.DOC_GEN_URL}/documents/merge`, body, {
130
+ responseType: 'arraybuffer',
131
+ });
132
+ }
133
+ getAttachments(searchRequest) {
134
+ return this.documentAttachmentService.getAttachments(searchRequest);
135
+ }
136
+ getAttachmentFile(id) {
137
+ return this.documentAttachmentService.getAttachmentFile(id);
138
+ }
139
+ createAttachment(attachment, file, reportProgress) {
140
+ return this.documentAttachmentService.createAttachment(attachment, file, reportProgress);
141
+ }
142
+ removeAttachment(id) {
143
+ return this.documentAttachmentService.removeAttachment(id);
144
+ }
145
+ generateDocumentData(template, object, params = {}) {
146
+ var _a;
147
+ if (isLegacyDocumentTemplate(template)) {
148
+ return this.generateDocumentDataLegacy(template, object, params);
98
149
  }
99
- const allQueries = [...((_c = template === null || template === void 0 ? void 0 : template.queries) !== null && _c !== void 0 ? _c : [])];
100
- const properties = ((_d = object === null || object === void 0 ? void 0 : object.context) === null || _d === void 0 ? void 0 : _d.properties) || (object === null || object === void 0 ? void 0 : object.properties) || {};
150
+ const templateProperties = (_a = template.properties) === null || _a === void 0 ? void 0 : _a.reduce((acc, { name, value }) => (Object.assign(Object.assign({}, acc), { [name]: this.mapBooleanIfAplicable(value) })), {});
151
+ /*
152
+ Resolve quote and template properties for now
153
+ When procedures are ready, whey will replace template scripts.
154
+
155
+ TODO: run procedure to resolve document data
156
+ */
157
+ return of(Object.assign(Object.assign({}, (typeof object === 'object' ? object : { object })), templateProperties));
158
+ }
159
+ generateDocument(template, object, params = {}) {
160
+ const documentData$ = this.generateDocumentData(template, object, Object.assign(Object.assign({}, params), { shouldPreventDownload: true }));
161
+ return zip(this.getTemplateFile(template.id), documentData$, this.resolveAttachments$(template)).pipe(switchMap(([templateFile, data, attachments]) => {
162
+ var _a, _b, _c, _d, _e, _f;
163
+ const document = DocxTemplater.generate(templateFile, data);
164
+ const properties = (_c = (_b = (_a = object === null || object === void 0 ? void 0 : object.context) === null || _a === void 0 ? void 0 : _a.properties) !== null && _b !== void 0 ? _b : object === null || object === void 0 ? void 0 : object.properties) !== null && _c !== void 0 ? _c : {};
165
+ const documentName = properties.Name || template.name;
166
+ const documentFormat = (_d = params.documentFormat) !== null && _d !== void 0 ? _d : (_f = (_e = template.properties) === null || _e === void 0 ? void 0 : _e.find(p => p.name === 'documentFormat')) === null || _f === void 0 ? void 0 : _f.value;
167
+ if (documentFormat === 'DOCX') {
168
+ this.fileDownloadService.processDownload(document, documentName);
169
+ return of(document);
170
+ }
171
+ return this.mergeDocuments(document, attachments).pipe(switchMap(pdf => {
172
+ if (params.attachToQuote && QuoteDraft.isQuote(object)) {
173
+ return this.quoteApiService
174
+ .attachDocument(object.quoteId, `${documentName}.pdf`, pdf)
175
+ .pipe(map(() => pdf));
176
+ }
177
+ return of(pdf);
178
+ }), map(pdf => {
179
+ const blob = new Blob([pdf]);
180
+ if (!params.shouldPreventDownload) {
181
+ this.fileDownloadService.processDownload(blob, `${documentName}.pdf`);
182
+ }
183
+ return blob;
184
+ }));
185
+ }));
186
+ }
187
+ generateDocumentDataLegacy(template, object, params = {}) {
188
+ var _a, _b, _c, _d;
189
+ const shouldPreventDownload = params.shouldPreventDownload;
190
+ const allQueries = [...((_a = template === null || template === void 0 ? void 0 : template.queries) !== null && _a !== void 0 ? _a : [])];
191
+ const properties = (_d = (_c = (_b = object === null || object === void 0 ? void 0 : object.context) === null || _b === void 0 ? void 0 : _b.properties) !== null && _c !== void 0 ? _c : object === null || object === void 0 ? void 0 : object.properties) !== null && _d !== void 0 ? _d : {};
101
192
  const accountId = properties === null || properties === void 0 ? void 0 : properties.AccountId;
102
193
  const userId = properties === null || properties === void 0 ? void 0 : properties.UserId;
103
194
  if (accountId) {
@@ -119,9 +210,7 @@ export class DocumentTemplatesApiService {
119
210
  });
120
211
  }
121
212
  const queries = allQueries.map(query => this.queryObject(query, { properties })) || [];
122
- return forkJoin([...queries])
123
- .pipe(defaultIfEmpty([]))
124
- .pipe(map(results => {
213
+ return forkJoin([...queries]).pipe(defaultIfEmpty([]), map(results => {
125
214
  var _a, _b, _c, _d;
126
215
  const queriesResult = _.chain(results)
127
216
  .reduce((acc, r) => {
@@ -132,7 +221,7 @@ export class DocumentTemplatesApiService {
132
221
  }, {})
133
222
  .value();
134
223
  const templateProperties = ((template === null || template === void 0 ? void 0 : template.properties) || []).reduce((trunk, { name, value }) => {
135
- return Object.assign(Object.assign({}, trunk), { [name]: mapBooleanIfAplicable(value) });
224
+ return Object.assign(Object.assign({}, trunk), { [name]: this.mapBooleanIfAplicable(value) });
136
225
  }, {});
137
226
  const data = Object.assign(Object.assign(Object.assign({}, (typeof object === 'object' ? object : { object })), queriesResult), templateProperties);
138
227
  if (template.script && template.script.trim().length) {
@@ -156,113 +245,13 @@ export class DocumentTemplatesApiService {
156
245
  return data;
157
246
  }));
158
247
  }
159
- generateDocument(template, object, params = {}) {
160
- const attachmentIds = (template.attachments || []).map(({ id }) => id).filter(Boolean);
161
- const { shouldUseLocalDocxTemplater } = params;
162
- return shouldUseLocalDocxTemplater && !(object instanceof QuoteDraft)
163
- ? this.generateDocumentNew(template, object, params)
164
- : this.generateWithBackendDocxTemplater({ template, quote: object, attachmentIds, params });
165
- }
166
- generateDocumentNew(template, object, params = {}) {
167
- const { attachToQuote, documentFormat, shouldPreventDownload } = params;
168
- const file$ = this.service.api({
169
- method: 'get',
170
- url: `/templates/${template.id}/file`,
171
- responseType: 'arraybuffer',
172
- });
173
- const attachmentIds = (template.attachments || []).map(({ id }) => id);
174
- const attachments$ = attachmentIds.length
175
- ? attachmentIds.map(attachmentId => {
176
- return this.documentAttachmentService.getAttachmentFile(attachmentId, true);
177
- })
178
- : [];
179
- const data$ = this.generateDocumentData(template, object, Object.assign(Object.assign({}, params), { shouldPreventDownload: true }));
180
- return zip(file$, data$, ...attachments$).pipe(switchMap(([file, data, ...attachments]) => {
181
- var _a;
182
- const d = DocxTemplater.generate(file, data);
183
- const body = new FormData();
184
- const properties = ((_a = object === null || object === void 0 ? void 0 : object.context) === null || _a === void 0 ? void 0 : _a.properties) || (object === null || object === void 0 ? void 0 : object.properties) || {};
185
- const documentName = (properties === null || properties === void 0 ? void 0 : properties.Name) || template.name;
186
- // TODO: special CATO case. Refactor for a more generic approach
187
- if (documentFormat === 'DOCX') {
188
- this.fileDownloadService.processDownload(d, documentName);
189
- return of(d);
190
- }
191
- attachments.forEach((attachment) => {
192
- body.append('attachments', new Blob([attachment]));
193
- });
194
- body.append('orderform', d);
195
- return this.http
196
- .post(`${this.docGenHost}/documents/merge`, body, {
197
- responseType: 'arraybuffer',
198
- })
199
- .pipe(switchMap((pdf) => {
200
- const blob = new Blob([pdf]);
201
- if (!shouldPreventDownload) {
202
- this.fileDownloadService.processDownload(blob, `${documentName}.pdf`);
203
- }
204
- if (attachToQuote && object instanceof QuoteDraft) {
205
- const formData = new FormData();
206
- formData.append('file', blob, `${documentName}.pdf`);
207
- return this.http.post(`${window['VELO_API']}/services/quotes/${object.quoteId}/attach-document`, formData, {
208
- responseType: 'arraybuffer',
209
- headers: {
210
- Authorization: window['VELO_KEY'],
211
- },
212
- });
213
- }
214
- return of(blob);
215
- }));
216
- }));
217
- }
218
- getAttachments(searchRequest) {
219
- return this.documentAttachmentService.getAttachments(searchRequest);
220
- }
221
- getAttachmentFile(id) {
222
- return this.documentAttachmentService.getAttachmentFile(id);
223
- }
224
- createAttachment(attachment, file, reportProgress) {
225
- return this.documentAttachmentService.createAttachment(attachment, file, reportProgress);
226
- }
227
- removeAttachment(id) {
228
- return this.documentAttachmentService.removeAttachment(id);
229
- }
230
- downloadTemplateFile(id) {
231
- return this.service
232
- .api({
233
- url: `/templates/${id}/file`,
234
- responseType: 'blob',
235
- observe: 'response',
236
- })
237
- .pipe(tap(response => {
238
- this.fileDownloadService.processDownload(response);
239
- }), map(response => response.body || response));
240
- }
241
- generateWithBackendDocxTemplater({ template, quote, attachmentIds, params, }) {
242
- const { shouldPreventDownload } = params;
243
- const nonEmptyParams = Object.keys(params || {})
244
- .filter(k => params[k] !== undefined)
245
- .reduce((obj, key) => {
246
- obj[key] = params[key];
247
- return obj;
248
- }, {});
249
- return this.generate(`/templates/${template.id}/generate`, { quote, attachments: attachmentIds }, Boolean(shouldPreventDownload), 'blob', nonEmptyParams, false);
250
- }
251
- generate(url, body, shouldPreventDownload, responseType, params, isUpload, reportProgress) {
252
- const requestOptions = {
253
- method: 'post',
254
- url,
255
- body,
256
- reportProgress,
257
- responseType,
258
- observe: shouldPreventDownload ? 'body' : 'response',
259
- params,
260
- };
261
- return (isUpload ? this.service.upload(requestOptions) : this.service.api(requestOptions)).pipe(tap(response => {
262
- if (!shouldPreventDownload) {
263
- this.fileDownloadService.processDownload(response);
264
- }
265
- }));
248
+ resolveAttachments$(template) {
249
+ var _a, _b;
250
+ const attachmentIds = (_b = (_a = template.attachments) === null || _a === void 0 ? void 0 : _a.map(({ id }) => id).filter(Boolean)) !== null && _b !== void 0 ? _b : [];
251
+ if (!attachmentIds.length) {
252
+ return of([]);
253
+ }
254
+ return forkJoin(attachmentIds.map(id => this.documentAttachmentService.getAttachmentFile(id, true)));
266
255
  }
267
256
  queryObject({ objectName, resultObjectName, fields, statement }, { properties }) {
268
257
  var _a;
@@ -277,12 +266,12 @@ export class DocumentTemplatesApiService {
277
266
  }
278
267
  const resolvedStatement = StringUtils.fillPlaceholders(statement, properties, /:\s*(\w[\w\d_.]+)/i);
279
268
  const searchRequest = Object.assign({ skip: 0, count: limit, rawCondition: resolvedStatement }, ((fields === null || fields === void 0 ? void 0 : fields.length) && !!fields[0] && { fields }));
280
- return this.sfRepo.query(searchRequest, objectName).pipe(mapSfQueryResult(limit), map(value => ({ [resultObjectName]: value })));
269
+ return this.salesforceApiService.query(searchRequest, objectName).pipe(this.mapSfQueryResult(limit), map(value => ({ [resultObjectName]: value })));
281
270
  }
282
271
  }
283
- DocumentTemplatesApiService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: DocumentTemplatesApiService, deps: [{ token: i1.BaseHttpService }, { token: i2.SalesforceApiService }, { token: i1.FileDownloadService }, { token: i3.DocumentAttachmentApiService }, { token: i4.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
272
+ DocumentTemplatesApiService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: DocumentTemplatesApiService, deps: [{ token: i1.BaseHttpService }, { token: i2.SalesforceApiService }, { token: i1.FileDownloadService }, { token: i3.DocumentAttachmentApiService }, { token: i4.QuoteApiService }, { token: i5.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
284
273
  DocumentTemplatesApiService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: DocumentTemplatesApiService });
285
274
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: DocumentTemplatesApiService, decorators: [{
286
275
  type: Injectable
287
- }], ctorParameters: function () { return [{ type: i1.BaseHttpService }, { type: i2.SalesforceApiService }, { type: i1.FileDownloadService }, { type: i3.DocumentAttachmentApiService }, { type: i4.HttpClient }]; } });
288
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"document-templates-api.service.js","sourceRoot":"","sources":["../../../../../../libs/api/src/lib/services/document-templates-api.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { CurrencyPipe } from '@angular/common';\nimport { HttpClient } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport {\n  AnyWithProperties,\n  BaseHttpService,\n  DocumentTemplate,\n  DocxTemplater,\n  FileDownloadService,\n  HttpRequestOptions,\n  QuoteDraft,\n  SearchRequest,\n  StringUtils,\n  TemplateAttachment,\n  TemplateAttachmentSearchRequest,\n  TemplateQuery,\n  VlWindow,\n} from '@veloce/core';\nimport * as _ from 'lodash';\nimport * as moment_ from 'moment';\nimport { forkJoin, Observable, of, zip } from 'rxjs';\nimport { defaultIfEmpty, map, switchMap, tap } from 'rxjs/operators';\nimport { DocumentAttachmentApiService } from './document-attachment-api.service';\nimport { SalesforceApiService } from './salesforce-api.service';\n\nconst moment = moment_;\ndeclare const window: VlWindow;\n\nconst mapSfQueryResult = <T>(limit: number) =>\n  map((records: T[]) => {\n    if (!records.length) {\n      return { _result: 'No Records Found' };\n    }\n\n    if (limit === 1) {\n      return records[0];\n    }\n\n    return records;\n  });\n\nconst mapBooleanIfAplicable = (value: string) => {\n  if (value === 'true') {\n    return true;\n  }\n\n  if (value === 'false') {\n    return false;\n  }\n\n  return value;\n};\n\n@Injectable()\nexport class DocumentTemplatesApiService {\n  private readonly fallbackDocGenHost = 'https://dev-dp1.velocpq.com/docgen';\n  private readonly docGenHost;\n  constructor(\n    private service: BaseHttpService,\n    private sfRepo: SalesforceApiService,\n    private fileDownloadService: FileDownloadService,\n    private documentAttachmentService: DocumentAttachmentApiService,\n    private http: HttpClient,\n  ) {\n    if (window.VELO_DOCGEN_API) {\n      this.docGenHost = window.VELO_DOCGEN_API;\n    } else {\n      console.log(`window.VELO_DOCGEN_API not set, will use fallback \"${this.fallbackDocGenHost}\"`);\n      this.docGenHost = this.fallbackDocGenHost;\n    }\n  }\n\n  getTemplates(tag?: string): Observable<DocumentTemplate[]> {\n    return this.service.api({\n      url: '/templates',\n      method: 'get',\n      params: {\n        ...(tag && { tag }),\n      },\n    });\n  }\n\n  upsertTemplate(template: DocumentTemplate, file?: File, reportProgress?: boolean): Observable<DocumentTemplate> {\n    const formData: FormData = new FormData();\n\n    if (file) {\n      formData.append('file', file, file.name);\n    }\n    formData.append(\n      'template',\n      new Blob([JSON.stringify(template)], {\n        type: 'application/json',\n      }),\n    );\n\n    return this.service.upload({\n      url: `/templates` + ((template.id && `/${template.id}`) || ''),\n      body: formData,\n      method: template.id ? 'put' : 'post',\n      reportProgress,\n    });\n  }\n\n  removeTemplate(id: string): Observable<DocumentTemplate> {\n    return this.service.api({\n      url: '/templates/' + id,\n      method: 'delete',\n    });\n  }\n\n  restoreTemplate(id: string): Observable<void> {\n    return this.service.api({\n      url: `/templates/${id}/restore`,\n      method: 'patch',\n    });\n  }\n\n  cloneTemplate(\n    id: string,\n    propertiesToOverride: Partial<DocumentTemplate> = {},\n  ): Observable<{ clonedRecordId: string }> {\n    return this.service.api({\n      url: '/templates/clone/' + id,\n      method: 'post',\n      body: {\n        id,\n        propertiesToOverride,\n      },\n    });\n  }\n\n  generateDocumentData(\n    template: DocumentTemplate,\n    object: any,\n    params?: { [param: string]: string | boolean },\n  ): Observable<any> {\n    const shouldPreventDownload = params?.shouldPreventDownload;\n    const useLocalDataGeneration = template.properties?.find(({ name }) => name === 'useLocalDataGeneration')?.value;\n\n    if (!useLocalDataGeneration && object instanceof QuoteDraft) {\n      return this.generate(\n        '/templates/generate-data',\n        { template, quote: object },\n        shouldPreventDownload as boolean,\n        shouldPreventDownload ? 'json' : 'blob',\n      );\n    }\n\n    const allQueries = [...(template?.queries ?? [])];\n    const properties = object?.context?.properties || object?.properties || {};\n\n    const accountId = properties?.AccountId;\n    const userId = properties?.UserId;\n\n    if (accountId) {\n      allQueries.push({\n        queryName: 'QuoteAccountQuery',\n        objectName: 'Account',\n        resultObjectName: 'account',\n        statement: `Id ='${accountId}'`,\n        fields: [],\n      });\n    }\n    if (userId) {\n      allQueries.push({\n        queryName: 'QuoteUserQuery',\n        objectName: 'User',\n        resultObjectName: 'agent',\n        statement: `Id ='${userId}'`,\n        fields: [],\n      });\n    }\n\n    const queries = allQueries.map(query => this.queryObject(query as TemplateQuery, { properties })) || [];\n\n    return forkJoin([...queries])\n      .pipe(defaultIfEmpty([] as any[]))\n      .pipe(\n        map(results => {\n          const queriesResult = _.chain(results)\n            .reduce((acc, r) => {\n              if (r) {\n                return { ...acc, ...r };\n              }\n\n              return acc;\n            }, {})\n            .value();\n\n          const templateProperties = (template?.properties || []).reduce((trunk, { name, value }) => {\n            return {\n              ...trunk,\n              [name as string]: mapBooleanIfAplicable(value as any),\n            };\n          }, {});\n\n          const data = {\n            ...(typeof object === 'object' ? object : { object }),\n            ...queriesResult,\n            ...templateProperties,\n          };\n\n          if (template.script && template.script.trim().length) {\n            const currencyFormat = template.properties?.find(({ name }) => name === 'currencyFormat')?.value || '1.2-2';\n            const dateFormat = template.properties?.find(({ name }) => name === 'dateFormat')?.value || 'D/MMM/YYYY';\n            const formatDate = (value: string) => {\n              return value ? moment(value).format(dateFormat) : value;\n            };\n            const transform = new Function(`return ${template.script}`)();\n            const transformedData = transform({\n              ...data,\n              utils: {\n                lodash: _,\n                currency: (value: any) => new CurrencyPipe('en-US').transform(value, 'USD', 'symbol', currencyFormat),\n                date: formatDate,\n              },\n              ToDay: formatDate(Date.now() as any),\n            });\n            if (!shouldPreventDownload) {\n              const blob = new Blob([JSON.stringify(transformedData)]);\n              this.fileDownloadService.processDownload(blob, 'data.json');\n            }\n            return transformedData;\n          }\n          return data;\n        }),\n      );\n  }\n\n  generateDocument(\n    template: DocumentTemplate,\n    object: any,\n    params: { [param: string]: string | boolean } = {},\n  ): Observable<any> {\n    const attachmentIds = (template.attachments || []).map(({ id }) => id).filter(Boolean) as string[];\n    const { shouldUseLocalDocxTemplater } = params;\n\n    return shouldUseLocalDocxTemplater && !(object instanceof QuoteDraft)\n      ? this.generateDocumentNew(template, object, params)\n      : this.generateWithBackendDocxTemplater({ template, quote: object as QuoteDraft, attachmentIds, params });\n  }\n\n  generateDocumentNew(\n    template: DocumentTemplate,\n    object: any,\n    params: { [param: string]: string | boolean } = {},\n  ): Observable<any> {\n    const { attachToQuote, documentFormat, shouldPreventDownload } = params;\n    const file$ = this.service.api({\n      method: 'get',\n      url: `/templates/${template.id}/file`,\n      responseType: 'arraybuffer',\n    });\n    const attachmentIds = (template.attachments || []).map(({ id }) => id);\n    const attachments$ = attachmentIds.length\n      ? attachmentIds.map(attachmentId => {\n          return this.documentAttachmentService.getAttachmentFile(attachmentId as string, true);\n        })\n      : [];\n\n    const data$ = this.generateDocumentData(template, object, { ...params, shouldPreventDownload: true });\n\n    return zip(file$, data$, ...attachments$).pipe(\n      switchMap(([file, data, ...attachments]) => {\n        const d = DocxTemplater.generate(file, data);\n        const body = new FormData();\n        const properties = object?.context?.properties || object?.properties || {};\n        const documentName = properties?.Name || template.name;\n\n        // TODO: special CATO case. Refactor for a more generic approach\n        if (documentFormat === 'DOCX') {\n          this.fileDownloadService.processDownload(d, documentName);\n\n          return of(d);\n        }\n\n        attachments.forEach((attachment: ArrayBuffer) => {\n          body.append('attachments', new Blob([attachment]));\n        });\n\n        body.append('orderform', d);\n\n        return this.http\n          .post(`${this.docGenHost}/documents/merge`, body, {\n            responseType: 'arraybuffer',\n          })\n          .pipe(\n            switchMap((pdf: any) => {\n              const blob = new Blob([pdf]);\n\n              if (!shouldPreventDownload) {\n                this.fileDownloadService.processDownload(blob, `${documentName}.pdf`);\n              }\n\n              if (attachToQuote && object instanceof QuoteDraft) {\n                const formData: FormData = new FormData();\n\n                formData.append('file', blob, `${documentName}.pdf`);\n\n                return this.http.post(\n                  `${window['VELO_API']}/services/quotes/${object.quoteId}/attach-document`,\n                  formData,\n                  {\n                    responseType: 'arraybuffer' as any,\n                    headers: {\n                      Authorization: window['VELO_KEY'] as string,\n                    },\n                  },\n                );\n              }\n\n              return of(blob);\n            }),\n          );\n      }),\n    );\n  }\n\n  getAttachments(searchRequest: TemplateAttachmentSearchRequest): Observable<TemplateAttachment[]> {\n    return this.documentAttachmentService.getAttachments(searchRequest);\n  }\n\n  getAttachmentFile(id: string): any {\n    return this.documentAttachmentService.getAttachmentFile(id);\n  }\n\n  createAttachment(\n    attachment: TemplateAttachment,\n    file?: File,\n    reportProgress?: boolean,\n  ): Observable<TemplateAttachment> {\n    return this.documentAttachmentService.createAttachment(attachment, file, reportProgress);\n  }\n\n  removeAttachment(id: string): Observable<unknown> {\n    return this.documentAttachmentService.removeAttachment(id);\n  }\n\n  downloadTemplateFile(id: string): Observable<Blob> {\n    return this.service\n      .api({\n        url: `/templates/${id}/file`,\n        responseType: 'blob',\n        observe: 'response',\n      })\n      .pipe(\n        tap(response => {\n          this.fileDownloadService.processDownload(response);\n        }),\n        map(response => response.body || response),\n      );\n  }\n\n  private generateWithBackendDocxTemplater({\n    template,\n    quote,\n    attachmentIds,\n    params,\n  }: {\n    template: DocumentTemplate;\n    quote: QuoteDraft;\n    attachmentIds: string[];\n    params: { [param: string]: string | boolean };\n  }): Observable<any> {\n    const { shouldPreventDownload } = params;\n    const nonEmptyParams = Object.keys(params || {})\n      .filter(k => params[k] !== undefined)\n      .reduce((obj, key) => {\n        (obj as any)[key] = params[key];\n        return obj;\n      }, {});\n    return this.generate(\n      `/templates/${template.id}/generate`,\n      { quote, attachments: attachmentIds },\n      Boolean(shouldPreventDownload),\n      'blob',\n      nonEmptyParams,\n      false,\n    );\n  }\n\n  private generate(\n    url: string,\n    body: any,\n    shouldPreventDownload: boolean,\n    responseType: 'arraybuffer' | 'blob' | 'json' | 'text',\n    params?: { [param: string]: string },\n    isUpload?: boolean,\n    reportProgress?: boolean,\n  ): Observable<any> {\n    const requestOptions: HttpRequestOptions = {\n      method: 'post',\n      url,\n      body,\n      reportProgress,\n      responseType,\n      observe: shouldPreventDownload ? ('body' as const) : ('response' as const),\n      params,\n    };\n    return (isUpload ? this.service.upload(requestOptions) : this.service.api(requestOptions)).pipe(\n      tap(response => {\n        if (!shouldPreventDownload) {\n          this.fileDownloadService.processDownload(response);\n        }\n      }),\n    );\n  }\n\n  private queryObject(\n    { objectName, resultObjectName, fields, statement }: TemplateQuery,\n    { properties }: AnyWithProperties,\n  ): Observable<any> {\n    const patternLimit = /(\\s*limit\\s\\d*)/i;\n    let limit = 1;\n    if (patternLimit.test(statement)) {\n      const limitStr = statement?.match(patternLimit)?.[1].trim().substring(5).trim();\n      if (limitStr) {\n        limit = Number.parseInt(limitStr, 10);\n      }\n      statement = statement.replace(patternLimit, '');\n    }\n\n    const resolvedStatement = StringUtils.fillPlaceholders(statement, properties, /:\\s*(\\w[\\w\\d_.]+)/i);\n\n    const searchRequest = {\n      skip: 0,\n      count: limit,\n      rawCondition: resolvedStatement,\n      ...(fields?.length && !!fields[0] && { fields }),\n    } as SearchRequest;\n\n    return this.sfRepo.query(searchRequest, objectName).pipe(\n      mapSfQueryResult(limit),\n      map(value => ({ [resultObjectName]: value })),\n    );\n  }\n}\n"]}
276
+ }], ctorParameters: function () { return [{ type: i1.BaseHttpService }, { type: i2.SalesforceApiService }, { type: i1.FileDownloadService }, { type: i3.DocumentAttachmentApiService }, { type: i4.QuoteApiService }, { type: i5.HttpClient }]; } });
277
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"document-templates-api.service.js","sourceRoot":"","sources":["../../../../../../libs/api/src/lib/services/document-templates-api.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { CurrencyPipe } from '@angular/common';\nimport { HttpClient } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport {\n  AnyWithProperties,\n  BaseHttpService,\n  DocumentTemplate,\n  DocxTemplater,\n  FileDownloadService,\n  isLegacyDocumentTemplate,\n  QuoteDraft,\n  SearchRequest,\n  StringUtils,\n  TemplateAttachment,\n  TemplateAttachmentSearchRequest,\n  TemplateQuery,\n  VlWindow,\n} from '@veloce/core';\nimport * as _ from 'lodash';\nimport * as moment_ from 'moment';\nimport { forkJoin, Observable, of, zip } from 'rxjs';\nimport { defaultIfEmpty, map, switchMap, tap } from 'rxjs/operators';\nimport { DocumentAttachmentApiService } from './document-attachment-api.service';\nimport { QuoteApiService } from './quote-api.service';\nimport { SalesforceApiService } from './salesforce-api.service';\n\nconst moment = moment_;\ndeclare const window: VlWindow;\n\nexport interface DocumentGenerationParams {\n  attachToQuote?: boolean;\n  documentFormat?: 'DOCX';\n  shouldPreventDownload?: boolean;\n}\n\n@Injectable()\nexport class DocumentTemplatesApiService {\n  private readonly SERVICE_URL = '/templates';\n  private readonly DOC_GEN_URL_FALLBACK = 'https://dev-dp1.velocpq.com/docgen';\n  private readonly DOC_GEN_URL;\n\n  constructor(\n    private service: BaseHttpService,\n    private salesforceApiService: SalesforceApiService,\n    private fileDownloadService: FileDownloadService,\n    private documentAttachmentService: DocumentAttachmentApiService,\n    private quoteApiService: QuoteApiService,\n    private http: HttpClient,\n  ) {\n    if (window.VELO_DOCGEN_API) {\n      this.DOC_GEN_URL = window.VELO_DOCGEN_API;\n    } else {\n      console.log(`window.VELO_DOCGEN_API not set, will use fallback \"${this.DOC_GEN_URL_FALLBACK}\"`);\n      this.DOC_GEN_URL = this.DOC_GEN_URL_FALLBACK;\n    }\n  }\n\n  public getTemplates(tag?: string): Observable<DocumentTemplate[]> {\n    return this.service.api({\n      url: `${this.SERVICE_URL}`,\n      method: 'get',\n      params: {\n        ...(tag && { tag }),\n      },\n    });\n  }\n\n  public getTemplate(id: string): Observable<DocumentTemplate> {\n    return this.service.api({\n      url: `${this.SERVICE_URL}/${id}`,\n      method: 'get',\n    });\n  }\n\n  public upsertTemplate(\n    template: DocumentTemplate,\n    file?: File,\n    reportProgress?: boolean,\n  ): Observable<DocumentTemplate> {\n    const formData: FormData = new FormData();\n\n    if (file) {\n      formData.append('file', file, file.name);\n    }\n    formData.append(\n      'template',\n      new Blob([JSON.stringify(template)], {\n        type: 'application/json',\n      }),\n    );\n\n    let url = `${this.SERVICE_URL}`;\n    if (template.id) {\n      url += `/${template.id}`;\n    }\n\n    return this.service.upload({\n      url,\n      body: formData,\n      method: template.id ? 'put' : 'post',\n      reportProgress,\n    });\n  }\n\n  public removeTemplate(id: string): Observable<DocumentTemplate> {\n    return this.service.api({\n      url: `${this.SERVICE_URL}/${id}`,\n      method: 'delete',\n    });\n  }\n\n  public restoreTemplate(id: string): Observable<void> {\n    return this.service.api({\n      url: `${this.SERVICE_URL}/${id}/restore`,\n      method: 'patch',\n    });\n  }\n\n  public cloneTemplate(\n    id: string,\n    propertiesToOverride: Partial<DocumentTemplate> = {},\n  ): Observable<{ clonedRecordId: string }> {\n    return this.service.api({\n      url: `${this.SERVICE_URL}/clone/${id}`,\n      method: 'post',\n      body: {\n        id,\n        propertiesToOverride,\n      },\n    });\n  }\n\n  public getTemplateFile(id: string): Observable<ArrayBuffer> {\n    return this.service.api({\n      method: 'get',\n      url: `${this.SERVICE_URL}/${id}/file`,\n      responseType: 'arraybuffer',\n    });\n  }\n\n  public downloadTemplateFile(id: string): Observable<Blob> {\n    return this.service\n      .api({\n        url: `${this.SERVICE_URL}/${id}/file`,\n        responseType: 'blob',\n        observe: 'response',\n      })\n      .pipe(\n        tap(response => {\n          this.fileDownloadService.processDownload(response);\n        }),\n        map(response => response.body || response),\n      );\n  }\n\n  public mergeDocuments(document: Blob, attachments: ArrayBuffer[]): Observable<ArrayBuffer> {\n    const body = new FormData();\n\n    attachments.forEach(attachment => {\n      body.append('attachments', new Blob([attachment]));\n    });\n\n    body.append('orderform', document);\n\n    return this.http.post(`${this.DOC_GEN_URL}/documents/merge`, body, {\n      responseType: 'arraybuffer',\n    });\n  }\n\n  public getAttachments(searchRequest: TemplateAttachmentSearchRequest): Observable<TemplateAttachment[]> {\n    return this.documentAttachmentService.getAttachments(searchRequest);\n  }\n\n  public getAttachmentFile(id: string): any {\n    return this.documentAttachmentService.getAttachmentFile(id);\n  }\n\n  public createAttachment(\n    attachment: TemplateAttachment,\n    file?: File,\n    reportProgress?: boolean,\n  ): Observable<TemplateAttachment> {\n    return this.documentAttachmentService.createAttachment(attachment, file, reportProgress);\n  }\n\n  public removeAttachment(id: string): Observable<unknown> {\n    return this.documentAttachmentService.removeAttachment(id);\n  }\n\n  public generateDocumentData(\n    template: DocumentTemplate,\n    object: any,\n    params: DocumentGenerationParams = {},\n  ): Observable<any> {\n    if (isLegacyDocumentTemplate(template)) {\n      return this.generateDocumentDataLegacy(template, object, params);\n    }\n\n    const templateProperties = template.properties?.reduce(\n      (acc, { name, value }) => ({ ...acc, [name]: this.mapBooleanIfAplicable(value) }),\n      {},\n    );\n\n    /*\n      Resolve quote and template properties for now\n      When procedures are ready, whey will replace template scripts.\n\n      TODO: run procedure to resolve document data\n    */\n    return of({\n      ...(typeof object === 'object' ? object : { object }),\n      ...templateProperties,\n    });\n  }\n\n  public generateDocument(\n    template: DocumentTemplate,\n    object: any,\n    params: DocumentGenerationParams = {},\n  ): Observable<Blob> {\n    const documentData$ = this.generateDocumentData(template, object, { ...params, shouldPreventDownload: true });\n\n    return zip(this.getTemplateFile(template.id), documentData$, this.resolveAttachments$(template)).pipe(\n      switchMap(([templateFile, data, attachments]) => {\n        const document = DocxTemplater.generate(templateFile, data);\n        const properties: _.Dictionary<string> = object?.context?.properties ?? object?.properties ?? {};\n        const documentName = properties.Name || template.name;\n\n        const documentFormat =\n          params.documentFormat ?? template.properties?.find(p => p.name === 'documentFormat')?.value;\n        if (documentFormat === 'DOCX') {\n          this.fileDownloadService.processDownload(document, documentName);\n\n          return of(document);\n        }\n\n        return this.mergeDocuments(document, attachments).pipe(\n          switchMap(pdf => {\n            if (params.attachToQuote && QuoteDraft.isQuote(object)) {\n              return this.quoteApiService\n                .attachDocument(object.quoteId, `${documentName}.pdf`, pdf)\n                .pipe(map(() => pdf));\n            }\n\n            return of(pdf);\n          }),\n          map(pdf => {\n            const blob = new Blob([pdf]);\n\n            if (!params.shouldPreventDownload) {\n              this.fileDownloadService.processDownload(blob, `${documentName}.pdf`);\n            }\n\n            return blob;\n          }),\n        );\n      }),\n    );\n  }\n\n  private generateDocumentDataLegacy(\n    template: DocumentTemplate,\n    object: any,\n    params: DocumentGenerationParams = {},\n  ): Observable<any> {\n    const shouldPreventDownload = params.shouldPreventDownload;\n    const allQueries: TemplateQuery[] = [...(template?.queries ?? [])];\n    const properties: _.Dictionary<string> = object?.context?.properties ?? object?.properties ?? {};\n    const accountId = properties?.AccountId;\n    const userId = properties?.UserId;\n\n    if (accountId) {\n      allQueries.push({\n        queryName: 'QuoteAccountQuery',\n        objectName: 'Account',\n        resultObjectName: 'account',\n        statement: `Id ='${accountId}'`,\n        fields: [],\n      });\n    }\n    if (userId) {\n      allQueries.push({\n        queryName: 'QuoteUserQuery',\n        objectName: 'User',\n        resultObjectName: 'agent',\n        statement: `Id ='${userId}'`,\n        fields: [],\n      });\n    }\n\n    const queries = allQueries.map(query => this.queryObject(query, { properties })) || [];\n\n    return forkJoin([...queries]).pipe(\n      defaultIfEmpty([] as any[]),\n      map(results => {\n        const queriesResult = _.chain(results)\n          .reduce((acc, r) => {\n            if (r) {\n              return { ...acc, ...r };\n            }\n\n            return acc;\n          }, {})\n          .value();\n\n        const templateProperties = (template?.properties || []).reduce((trunk, { name, value }) => {\n          return {\n            ...trunk,\n            [name as string]: this.mapBooleanIfAplicable(value as any),\n          };\n        }, {});\n\n        const data = {\n          ...(typeof object === 'object' ? object : { object }),\n          ...queriesResult,\n          ...templateProperties,\n        };\n\n        if (template.script && template.script.trim().length) {\n          const currencyFormat = template.properties?.find(({ name }) => name === 'currencyFormat')?.value || '1.2-2';\n          const dateFormat = template.properties?.find(({ name }) => name === 'dateFormat')?.value || 'D/MMM/YYYY';\n          const formatDate = (value: string) => {\n            return value ? moment(value).format(dateFormat) : value;\n          };\n          const transform = new Function(`return ${template.script}`)();\n          const transformedData = transform({\n            ...data,\n            utils: {\n              lodash: _,\n              currency: (value: any) => new CurrencyPipe('en-US').transform(value, 'USD', 'symbol', currencyFormat),\n              date: formatDate,\n            },\n            ToDay: formatDate(Date.now() as any),\n          });\n          if (!shouldPreventDownload) {\n            const blob = new Blob([JSON.stringify(transformedData)]);\n            this.fileDownloadService.processDownload(blob, 'data.json');\n          }\n          return transformedData;\n        }\n        return data;\n      }),\n    );\n  }\n\n  private resolveAttachments$(template: DocumentTemplate): Observable<ArrayBuffer[]> {\n    const attachmentIds = (template.attachments?.map(({ id }) => id).filter(Boolean) as string[]) ?? [];\n\n    if (!attachmentIds.length) {\n      return of([]);\n    }\n\n    return forkJoin(attachmentIds.map(id => this.documentAttachmentService.getAttachmentFile(id, true)));\n  }\n\n  private mapSfQueryResult = <T>(limit: number) =>\n    map((records: T[]) => {\n      if (!records.length) {\n        return { _result: 'No Records Found' };\n      }\n\n      if (limit === 1) {\n        return records[0];\n      }\n\n      return records;\n    });\n\n  private mapBooleanIfAplicable = (value: string) => {\n    if (value === 'true') {\n      return true;\n    }\n\n    if (value === 'false') {\n      return false;\n    }\n\n    return value;\n  };\n\n  private queryObject(\n    { objectName, resultObjectName, fields, statement }: TemplateQuery,\n    { properties }: AnyWithProperties,\n  ): Observable<any> {\n    const patternLimit = /(\\s*limit\\s\\d*)/i;\n    let limit = 1;\n    if (patternLimit.test(statement)) {\n      const limitStr = statement?.match(patternLimit)?.[1].trim().substring(5).trim();\n      if (limitStr) {\n        limit = Number.parseInt(limitStr, 10);\n      }\n      statement = statement.replace(patternLimit, '');\n    }\n\n    const resolvedStatement = StringUtils.fillPlaceholders(statement, properties, /:\\s*(\\w[\\w\\d_.]+)/i);\n\n    const searchRequest = {\n      skip: 0,\n      count: limit,\n      rawCondition: resolvedStatement,\n      ...(fields?.length && !!fields[0] && { fields }),\n    } as SearchRequest;\n\n    return this.salesforceApiService.query(searchRequest, objectName).pipe(\n      this.mapSfQueryResult(limit),\n      map(value => ({ [resultObjectName]: value })),\n    );\n  }\n}\n"]}