@veloceapps/api 11.0.0-0 → 11.0.0-2

Sign up to get free protection for your applications and to get access to all the features.
package/index.d.ts CHANGED
@@ -10,7 +10,6 @@ export { ContextApiService } from './lib/services/context-api.service';
10
10
  export { ContractedPriceApiService } from './lib/services/contracted-price-api.service';
11
11
  export { DeltaApiService } from './lib/services/delta-api.service';
12
12
  export { DocumentAttachmentApiService } from './lib/services/document-attachment-api.service';
13
- export { DocumentTemplatesApiService } from './lib/services/document-templates-api.service';
14
13
  export { EndpointsApiService } from './lib/services/endpoints-api.service';
15
14
  export { FlowStateApiService } from './lib/services/flow-state-api';
16
15
  export { FlowsApiService } from './lib/services/flows-api.service';
@@ -1,5 +1,6 @@
1
- import { Attachment, BaseHttpService, FileDownloadService, TemplateAttachmentSearchRequest } from '@veloceapps/core';
1
+ import { Attachment, BaseHttpService, FileDownloadService } from '@veloceapps/core';
2
2
  import { Observable } from 'rxjs';
3
+ import { TemplateAttachmentSearchRequest } from '../types/attachment.types';
3
4
  import * as i0 from "@angular/core";
4
5
  export declare class DocumentAttachmentApiService {
5
6
  private httpService;
@@ -1,4 +1,4 @@
1
- import { BaseHttpService, ModelReleaseRequest, PmlConfigurationMode, ProductModel, ProductModelsContainer, ProductModelVersion } from '@veloceapps/core';
1
+ import { BaseHttpService, ModelReleaseRequest, PmlConfigurationMode, ProductModel, ProductModelVersion } from '@veloceapps/core';
2
2
  import { Observable } from 'rxjs';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class ProductModelApiService {
@@ -13,12 +13,6 @@ export declare class ProductModelApiService {
13
13
  getModel(id: string, version?: string): Observable<ProductModel>;
14
14
  getModels(skipCount: number, searchText: string): Observable<ProductModel[]>;
15
15
  getLinkedModels(id: string, version?: string): Observable<ProductModel[]>;
16
- /**
17
- *
18
- * @deprecated
19
- * Will be removed in next major release
20
- */
21
- load(id: string, version?: string): Observable<ProductModelsContainer>;
22
16
  getPML(modelId: string, version?: string): Observable<any>;
23
17
  savePML(modelId: string, pml: string, comment: string): Observable<any>;
24
18
  generateProducts(modelId: string): Observable<ProductModel>;
@@ -8,11 +8,7 @@ export declare class QuoteApiService {
8
8
  private readonly SERVICE_URL;
9
9
  constructor(httpService: BaseHttpService);
10
10
  /**
11
- * @deprecated Use getQuoteState instead
12
- */
13
- getQuoteDraft(objectId: string, params?: Dictionary<string>, errorHandler?: (error: any) => void): Observable<QuoteDraft>;
14
- /**
15
- * Comparing to deprecated `getQuoteDraft` this endpoint doesn't include orders and assets
11
+ * This endpoint doesn't include orders and assets
16
12
  * @param objectId quoteId | accountId | opportunityId | orderId
17
13
  * @param params Query params
18
14
  * @param options Request options
@@ -13,10 +13,6 @@ export declare class SalesforceApiService {
13
13
  }, options?: HttpRequestConfigurableOptions): Observable<{
14
14
  searchRecords: T[];
15
15
  }>;
16
- /**
17
- * @deprecated
18
- */
19
- describe(objectName: string, fieldName?: string, options?: HttpRequestConfigurableOptions): Observable<SalesforceField[]>;
20
16
  describeObject(objectName: string, options?: HttpRequestConfigurableOptions): Observable<SalesforceField[]>;
21
17
  describeField(objectName: string, fieldName: string, options?: HttpRequestConfigurableOptions): Observable<SalesforceField>;
22
18
  describe2<T>(objectName: string, fields: string[], options?: HttpRequestConfigurableOptions): Observable<T>;
@@ -0,0 +1,4 @@
1
+ export interface TemplateAttachmentSearchRequest {
2
+ linkedEntityId: string;
3
+ tag?: string;
4
+ }
@@ -7,7 +7,6 @@ export interface OrgInfo {
7
7
  OrgID: string;
8
8
  BackendURL: string;
9
9
  FrontendURL: string;
10
- DocgenURL: string;
11
10
  StudioURL: string;
12
11
  IntegrationURL: string;
13
12
  ShoppingCartURL: string;
@@ -15,7 +14,6 @@ export interface OrgInfo {
15
14
  DefaultDataURL: string;
16
15
  BackendVersion: string;
17
16
  FrontendVersion: string;
18
- DocgenVersion: string;
19
17
  StudioVersion: string;
20
18
  IntegrationVersion: string;
21
19
  ShoppingCartVersion: string;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@veloceapps/api",
3
- "version": "11.0.0-0",
3
+ "version": "11.0.0-2",
4
4
  "private": false,
5
5
  "peerDependencies": {
6
6
  "@angular/common": "~15.2.0",
@@ -1,323 +0,0 @@
1
- import { CurrencyPipe } from '@angular/common';
2
- import { Injectable } from '@angular/core';
3
- import { DocxTemplater, isLegacyDocumentTemplate, QuoteDraft, StringUtils, } from '@veloceapps/core';
4
- import * as _ from 'lodash';
5
- import moment from 'moment';
6
- import { forkJoin, of, zip } from 'rxjs';
7
- import { defaultIfEmpty, map, switchMap, tap } from 'rxjs/operators';
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "@veloceapps/core";
10
- import * as i2 from "./salesforce-api.service";
11
- import * as i3 from "./document-attachment-api.service";
12
- import * as i4 from "@angular/common/http";
13
- export class DocumentTemplatesApiService {
14
- constructor(service, salesforceApiService, fileDownloadService, documentAttachmentService, http) {
15
- this.service = service;
16
- this.salesforceApiService = salesforceApiService;
17
- this.fileDownloadService = fileDownloadService;
18
- this.documentAttachmentService = documentAttachmentService;
19
- this.http = http;
20
- this.SERVICE_URL = '/templates';
21
- this.DOCGEN_TAG = 'docgen';
22
- this.DOC_GEN_URL_FALLBACK = `${window.VELO_API}/docgen`;
23
- this.mapSfQueryResult = (limit) => map((records) => {
24
- if (!records.length) {
25
- return { _result: 'No Records Found' };
26
- }
27
- if (limit === 1) {
28
- return records[0];
29
- }
30
- return records;
31
- });
32
- this.mapBooleanIfAplicable = (value) => {
33
- if (value === 'true') {
34
- return true;
35
- }
36
- if (value === 'false') {
37
- return false;
38
- }
39
- return value;
40
- };
41
- if (window.VELO_DOCGEN_API) {
42
- this.DOC_GEN_URL = window.VELO_DOCGEN_API;
43
- }
44
- else {
45
- console.log(`window.VELO_DOCGEN_API not set, will use fallback "${this.DOC_GEN_URL_FALLBACK}"`);
46
- this.DOC_GEN_URL = this.DOC_GEN_URL_FALLBACK;
47
- }
48
- }
49
- getTemplates(tag) {
50
- return this.service.api({
51
- url: `${this.SERVICE_URL}`,
52
- method: 'get',
53
- params: {
54
- ...(tag && { tag }),
55
- },
56
- });
57
- }
58
- getTemplate(id) {
59
- return this.service.api({
60
- url: `${this.SERVICE_URL}/${id}`,
61
- method: 'get',
62
- });
63
- }
64
- upsertTemplate(template, file, reportProgress) {
65
- const formData = new FormData();
66
- if (file) {
67
- formData.append('file', file, file.name);
68
- }
69
- formData.append('template', new Blob([JSON.stringify(template)], {
70
- type: 'application/json',
71
- }));
72
- let url = `${this.SERVICE_URL}`;
73
- if (template.id) {
74
- url += `/${template.id}`;
75
- }
76
- return this.service.upload({
77
- url,
78
- body: formData,
79
- method: template.id ? 'put' : 'post',
80
- reportProgress,
81
- });
82
- }
83
- removeTemplate(id) {
84
- return this.service.api({
85
- url: `${this.SERVICE_URL}/${id}`,
86
- method: 'delete',
87
- });
88
- }
89
- restoreTemplate(id) {
90
- return this.service.api({
91
- url: `${this.SERVICE_URL}/${id}/restore`,
92
- method: 'patch',
93
- });
94
- }
95
- cloneTemplate(id, propertiesToOverride = {}) {
96
- return this.service.api({
97
- url: `${this.SERVICE_URL}/clone/${id}`,
98
- method: 'post',
99
- body: {
100
- id,
101
- propertiesToOverride,
102
- },
103
- });
104
- }
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
- generateDocumentV2(body, quoteId, isAsync) {
134
- body['docgenURL'] = window.VELO_DOCGEN_API ?? '';
135
- const params = {};
136
- if (isAsync) {
137
- params['async'] = 'true';
138
- }
139
- return this.service
140
- .api({
141
- method: 'post',
142
- url: `/docgen/${quoteId}/generate`,
143
- body,
144
- params,
145
- responseType: 'arraybuffer',
146
- })
147
- .pipe(map(pdf => {
148
- const blob = new Blob([pdf]);
149
- const documentName = body.parameters['documentName'] ?? 'Veloce Proposal';
150
- if (!isAsync) {
151
- this.fileDownloadService.processDownload(blob, `${documentName}.${body.documentFormat.toLowerCase()}`);
152
- }
153
- return blob;
154
- }));
155
- }
156
- getAttachments(searchRequest) {
157
- return this.documentAttachmentService.getAttachments(searchRequest);
158
- }
159
- getAttachmentFile(id) {
160
- return this.documentAttachmentService.getAttachmentFile(id);
161
- }
162
- createAttachment(attachment, file, reportProgress) {
163
- return this.documentAttachmentService.createAttachment(attachment, file, reportProgress);
164
- }
165
- removeAttachment(id) {
166
- return this.documentAttachmentService.removeAttachment(id);
167
- }
168
- generateDocumentData(template, object, params = {}) {
169
- if (isLegacyDocumentTemplate(template)) {
170
- return this.generateDocumentDataLegacy(template, object, params);
171
- }
172
- const templateProperties = template.properties?.reduce((acc, { name, value }) => ({ ...acc, [name]: this.mapBooleanIfAplicable(value) }), {});
173
- /*
174
- Resolve quote and template properties for now
175
- When procedures are ready, whey will replace template scripts.
176
-
177
- TODO: run procedure to resolve document data
178
- */
179
- return of({
180
- ...(typeof object === 'object' ? object : { object }),
181
- ...templateProperties,
182
- });
183
- }
184
- generateDocument(template, object, params = {}) {
185
- const documentData$ = this.generateDocumentData(template, object, { ...params, shouldPreventDownload: true });
186
- return zip(this.getTemplateFile(template.id), documentData$, this.resolveAttachments$(template)).pipe(switchMap(([templateFile, data, attachments]) => {
187
- const document = DocxTemplater.generate(templateFile, data);
188
- const properties = object?.context?.properties ?? object?.properties ?? {};
189
- const documentName = template.properties?.find(({ name }) => name === 'documentName')?.value ||
190
- properties['Name'] ||
191
- template.name;
192
- const documentFormat = params.documentFormat ?? template.properties?.find(p => p.name === 'documentFormat')?.value;
193
- if (documentFormat === 'DOCX') {
194
- this.fileDownloadService.processDownload(document, documentName);
195
- return of(document);
196
- }
197
- return this.mergeDocuments(document, attachments).pipe(switchMap(pdf => {
198
- if (params.attachToQuote && QuoteDraft.isQuote(object)) {
199
- const file = new File([pdf], `${documentName}.pdf`);
200
- return this.documentAttachmentService
201
- .createAttachment({
202
- linkedEntityId: object.quoteId,
203
- fileName: documentName,
204
- fileExtension: 'pdf',
205
- tags: this.DOCGEN_TAG,
206
- }, file)
207
- .pipe(map(() => pdf));
208
- }
209
- return of(pdf);
210
- }), map(pdf => {
211
- const blob = new Blob([pdf]);
212
- if (!params.shouldPreventDownload) {
213
- this.fileDownloadService.processDownload(blob, `${documentName}.pdf`);
214
- }
215
- return blob;
216
- }));
217
- }));
218
- }
219
- generateDocumentDataLegacy(template, object, params = {}) {
220
- const shouldPreventDownload = params.shouldPreventDownload;
221
- const allQueries = [...(template?.queries ?? [])];
222
- const properties = object?.context?.properties ?? object?.properties ?? {};
223
- const accountId = properties?.['AccountId'];
224
- const userId = properties?.['UserId'];
225
- if (accountId) {
226
- allQueries.push({
227
- queryName: 'QuoteAccountQuery',
228
- objectName: 'Account',
229
- resultObjectName: 'account',
230
- statement: `Id ='${accountId}'`,
231
- fields: [],
232
- });
233
- }
234
- if (userId) {
235
- allQueries.push({
236
- queryName: 'QuoteUserQuery',
237
- objectName: 'User',
238
- resultObjectName: 'agent',
239
- statement: `Id ='${userId}'`,
240
- fields: [],
241
- });
242
- }
243
- const queries = allQueries.map(query => this.queryObject(query, { properties })) || [];
244
- return forkJoin([...queries]).pipe(defaultIfEmpty([]), map(results => {
245
- const queriesResult = _.chain(results)
246
- .reduce((acc, r) => {
247
- if (r) {
248
- return { ...acc, ...r };
249
- }
250
- return acc;
251
- }, {})
252
- .value();
253
- const templateProperties = (template?.properties || []).reduce((trunk, { name, value }) => {
254
- return {
255
- ...trunk,
256
- [name]: this.mapBooleanIfAplicable(value),
257
- };
258
- }, {});
259
- const data = {
260
- ...(typeof object === 'object' ? object : { object }),
261
- ...queriesResult,
262
- ...templateProperties,
263
- };
264
- if (template.script && template.script.trim().length) {
265
- const currencyFormat = template.properties?.find(({ name }) => name === 'currencyFormat')?.value || '1.2-2';
266
- const dateFormat = template.properties?.find(({ name }) => name === 'dateFormat')?.value || 'D/MMM/YYYY';
267
- const formatDate = (value) => {
268
- return value ? moment(value).format(dateFormat) : value;
269
- };
270
- const transform = new Function(`return ${template.script}`)();
271
- const transformedData = transform({
272
- ...data,
273
- utils: {
274
- lodash: _,
275
- currency: (value) => new CurrencyPipe('en-US').transform(value, 'USD', 'symbol', currencyFormat),
276
- date: formatDate,
277
- },
278
- ToDay: formatDate(Date.now()),
279
- });
280
- if (!shouldPreventDownload) {
281
- const blob = new Blob([JSON.stringify(transformedData)]);
282
- this.fileDownloadService.processDownload(blob, 'data.json');
283
- }
284
- return transformedData;
285
- }
286
- return data;
287
- }));
288
- }
289
- resolveAttachments$(template) {
290
- const attachmentIds = template.attachments?.map(({ id }) => id).filter(Boolean) ?? [];
291
- if (!attachmentIds.length) {
292
- return of([]);
293
- }
294
- return forkJoin(attachmentIds.map(id => this.documentAttachmentService.getAttachmentFile(id, true)));
295
- }
296
- queryObject({ objectName, resultObjectName, fields, statement }, { properties }) {
297
- const patternLimit = /(\s*limit\s\d*)/i;
298
- let limit = 1;
299
- if (statement && patternLimit.test(statement)) {
300
- const limitStr = statement?.match(patternLimit)?.[1]?.trim().substring(5).trim();
301
- if (limitStr) {
302
- limit = Number.parseInt(limitStr, 10);
303
- }
304
- statement = statement.replace(patternLimit, '');
305
- }
306
- const resolvedStatement = statement
307
- ? StringUtils.fillPlaceholders(statement, properties, /:\s*(\w[\w\d_.]+)/i)
308
- : undefined;
309
- const searchRequest = {
310
- skip: 0,
311
- count: limit,
312
- rawCondition: resolvedStatement,
313
- ...(fields?.length && !!fields[0] && { fields }),
314
- };
315
- return this.salesforceApiService.query(searchRequest, objectName).pipe(this.mapSfQueryResult(limit), map(value => ({ [resultObjectName]: value })));
316
- }
317
- }
318
- DocumentTemplatesApiService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DocumentTemplatesApiService, deps: [{ token: i1.BaseHttpService }, { token: i2.SalesforceApiService }, { token: i1.FileDownloadService }, { token: i3.DocumentAttachmentApiService }, { token: i4.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
319
- DocumentTemplatesApiService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DocumentTemplatesApiService });
320
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DocumentTemplatesApiService, decorators: [{
321
- type: Injectable
322
- }], ctorParameters: function () { return [{ type: i1.BaseHttpService }, { type: i2.SalesforceApiService }, { type: i1.FileDownloadService }, { type: i3.DocumentAttachmentApiService }, { type: i4.HttpClient }]; } });
323
- //# 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 { Injectable } from '@angular/core';\nimport { HttpClient } from '@angular/common/http';\nimport {\n  AnyWithProperties,\n  Attachment,\n  BaseHttpService,\n  DocumentTemplate,\n  DocxTemplater,\n  FileDownloadService,\n  GenerateDocumentPayload,\n  isLegacyDocumentTemplate,\n  QuoteDraft,\n  SearchRequest,\n  StringUtils,\n  TemplateAttachmentSearchRequest,\n  TemplateQuery,\n  VlWindow,\n} from '@veloceapps/core';\nimport * as _ from 'lodash';\nimport { Dictionary } from 'lodash';\nimport 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\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  public readonly DOCGEN_TAG = 'docgen';\n  private readonly DOC_GEN_URL_FALLBACK = `${window.VELO_API}/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 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 generateDocumentV2(body: GenerateDocumentPayload, quoteId: string, isAsync?: boolean): Observable<Blob> {\n    body['docgenURL'] = window.VELO_DOCGEN_API ?? '';\n\n    const params: Dictionary<string> = {};\n    if (isAsync) {\n      params['async'] = 'true';\n    }\n\n    return this.service\n      .api({\n        method: 'post',\n        url: `/docgen/${quoteId}/generate`,\n        body,\n        params,\n        responseType: 'arraybuffer',\n      })\n      .pipe(\n        map(pdf => {\n          const blob = new Blob([pdf]);\n\n          const documentName = body.parameters['documentName'] ?? 'Veloce Proposal';\n\n          if (!isAsync) {\n            this.fileDownloadService.processDownload(blob, `${documentName}.${body.documentFormat.toLowerCase()}`);\n          }\n\n          return blob;\n        }),\n      );\n  }\n\n  public getAttachments(searchRequest: TemplateAttachmentSearchRequest): Observable<Attachment[]> {\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(attachment: Attachment, file?: File, reportProgress?: boolean): Observable<Attachment> {\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 =\n          template.properties?.find(({ name }) => name === 'documentName')?.value ||\n          properties['Name'] ||\n          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              const file = new File([pdf], `${documentName}.pdf`);\n              return this.documentAttachmentService\n                .createAttachment(\n                  {\n                    linkedEntityId: object.quoteId,\n                    fileName: documentName,\n                    fileExtension: 'pdf',\n                    tags: this.DOCGEN_TAG,\n                  },\n                  file,\n                )\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 (statement && 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 = statement\n      ? StringUtils.fillPlaceholders(statement, properties, /:\\s*(\\w[\\w\\d_.]+)/i)\n      : undefined;\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"]}
@@ -1,48 +0,0 @@
1
- import { HttpClient } from '@angular/common/http';
2
- import { Attachment, BaseHttpService, DocumentTemplate, FileDownloadService, GenerateDocumentPayload, TemplateAttachmentSearchRequest } from '@veloceapps/core';
3
- import { Observable } from 'rxjs';
4
- import { DocumentAttachmentApiService } from './document-attachment-api.service';
5
- import { SalesforceApiService } from './salesforce-api.service';
6
- import * as i0 from "@angular/core";
7
- export interface DocumentGenerationParams {
8
- attachToQuote?: boolean;
9
- documentFormat?: 'DOCX';
10
- shouldPreventDownload?: boolean;
11
- }
12
- export declare class DocumentTemplatesApiService {
13
- private service;
14
- private salesforceApiService;
15
- private fileDownloadService;
16
- private documentAttachmentService;
17
- private http;
18
- private readonly SERVICE_URL;
19
- readonly DOCGEN_TAG = "docgen";
20
- private readonly DOC_GEN_URL_FALLBACK;
21
- private readonly DOC_GEN_URL;
22
- constructor(service: BaseHttpService, salesforceApiService: SalesforceApiService, fileDownloadService: FileDownloadService, documentAttachmentService: DocumentAttachmentApiService, http: HttpClient);
23
- getTemplates(tag?: string): Observable<DocumentTemplate[]>;
24
- getTemplate(id: string): Observable<DocumentTemplate>;
25
- upsertTemplate(template: DocumentTemplate, file?: File, reportProgress?: boolean): Observable<DocumentTemplate>;
26
- removeTemplate(id: string): Observable<DocumentTemplate>;
27
- restoreTemplate(id: string): Observable<void>;
28
- cloneTemplate(id: string, propertiesToOverride?: Partial<DocumentTemplate>): Observable<{
29
- clonedRecordId: string;
30
- }>;
31
- getTemplateFile(id: string): Observable<ArrayBuffer>;
32
- downloadTemplateFile(id: string): Observable<Blob>;
33
- mergeDocuments(document: Blob, attachments: ArrayBuffer[]): Observable<ArrayBuffer>;
34
- generateDocumentV2(body: GenerateDocumentPayload, quoteId: string, isAsync?: boolean): Observable<Blob>;
35
- getAttachments(searchRequest: TemplateAttachmentSearchRequest): Observable<Attachment[]>;
36
- getAttachmentFile(id: string): any;
37
- createAttachment(attachment: Attachment, file?: File, reportProgress?: boolean): Observable<Attachment>;
38
- removeAttachment(id: string): Observable<unknown>;
39
- generateDocumentData(template: DocumentTemplate, object: any, params?: DocumentGenerationParams): Observable<any>;
40
- generateDocument(template: DocumentTemplate, object: any, params?: DocumentGenerationParams): Observable<Blob>;
41
- private generateDocumentDataLegacy;
42
- private resolveAttachments$;
43
- private mapSfQueryResult;
44
- private mapBooleanIfAplicable;
45
- private queryObject;
46
- static ɵfac: i0.ɵɵFactoryDeclaration<DocumentTemplatesApiService, never>;
47
- static ɵprov: i0.ɵɵInjectableDeclaration<DocumentTemplatesApiService>;
48
- }