@veloceapps/api 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +7 -0
- package/bundles/veloce-api.umd.js +2117 -0
- package/bundles/veloce-api.umd.js.map +1 -0
- package/esm2015/index.js +14 -0
- package/esm2015/lib/api.module.js +59 -0
- package/esm2015/lib/services/configuration-api.service.js +90 -0
- package/esm2015/lib/services/configuration-settings-api.service.js +69 -0
- package/esm2015/lib/services/context-api.service.js +26 -0
- package/esm2015/lib/services/document-attachment-api.service.js +65 -0
- package/esm2015/lib/services/document-templates-api.service.js +278 -0
- package/esm2015/lib/services/price-api.service.js +86 -0
- package/esm2015/lib/services/product-model-api.service.js +232 -0
- package/esm2015/lib/services/quote-api.service.js +36 -0
- package/esm2015/lib/services/ramp-api.service.js +42 -0
- package/esm2015/lib/services/salesforce-api.service.js +51 -0
- package/esm2015/lib/services/scripts-api.service.js +75 -0
- package/esm2015/lib/services/ui-templates-api.service.js +262 -0
- package/esm2015/lib/types/attribute-dto.types.js +21 -0
- package/esm2015/lib/types/charge-group-item-dto.types.js +45 -0
- package/esm2015/lib/types/charge-item-dto.types.js +74 -0
- package/esm2015/lib/types/clone-request.types.js +2 -0
- package/esm2015/lib/types/configuration-settings-dto.types.js +22 -0
- package/esm2015/lib/types/domain-type-dto.types.js +27 -0
- package/esm2015/lib/types/line-item-dto.types.js +93 -0
- package/esm2015/lib/types/port-domain-dto.types.js +22 -0
- package/esm2015/lib/types/price-adjustment-dto.types.js +15 -0
- package/esm2015/lib/types/price-dto.types.js +25 -0
- package/esm2015/lib/types/recommended-price-dto.types.js +23 -0
- package/esm2015/lib/types/ui-template-dto.types.js +2 -0
- package/esm2015/lib/utils/ui-template.utils.js +17 -0
- package/esm2015/veloce-api.js +5 -0
- package/fesm2015/veloce-api.js +1686 -0
- package/fesm2015/veloce-api.js.map +1 -0
- package/index.d.ts +14 -0
- package/lib/api.module.d.ts +7 -0
- package/lib/services/configuration-api.service.d.ts +18 -0
- package/lib/services/configuration-settings-api.service.d.ts +17 -0
- package/lib/services/context-api.service.d.ts +11 -0
- package/lib/services/document-attachment-api.service.d.ts +15 -0
- package/lib/services/document-templates-api.service.d.ts +39 -0
- package/lib/services/price-api.service.d.ts +16 -0
- package/lib/services/product-model-api.service.d.ts +30 -0
- package/lib/services/quote-api.service.d.ts +14 -0
- package/lib/services/ramp-api.service.d.ts +12 -0
- package/lib/services/salesforce-api.service.d.ts +17 -0
- package/lib/services/scripts-api.service.d.ts +21 -0
- package/lib/services/ui-templates-api.service.d.ts +47 -0
- package/lib/types/attribute-dto.types.d.ts +11 -0
- package/lib/types/charge-group-item-dto.types.d.ts +24 -0
- package/lib/types/charge-item-dto.types.d.ts +39 -0
- package/lib/types/clone-request.types.d.ts +6 -0
- package/lib/types/configuration-settings-dto.types.d.ts +9 -0
- package/lib/types/domain-type-dto.types.d.ts +15 -0
- package/lib/types/line-item-dto.types.d.ts +50 -0
- package/lib/types/port-domain-dto.types.d.ts +13 -0
- package/lib/types/price-adjustment-dto.types.d.ts +8 -0
- package/lib/types/price-dto.types.d.ts +13 -0
- package/lib/types/recommended-price-dto.types.d.ts +12 -0
- package/lib/types/ui-template-dto.types.d.ts +10 -0
- package/lib/utils/ui-template.utils.d.ts +3 -0
- package/package.json +33 -0
- package/veloce-api.d.ts +5 -0
@@ -0,0 +1,69 @@
|
|
1
|
+
import { Injectable } from '@angular/core';
|
2
|
+
import { map } from 'rxjs/operators';
|
3
|
+
import { ConfigurationSettingsDTO } from '../types/configuration-settings-dto.types';
|
4
|
+
import * as i0 from "@angular/core";
|
5
|
+
import * as i1 from "@veloce/core";
|
6
|
+
export class ConfigurationSettingsApiService {
|
7
|
+
constructor(httpService) {
|
8
|
+
this.httpService = httpService;
|
9
|
+
this.SERVICE_URL = '/configuration-settings';
|
10
|
+
}
|
11
|
+
fetchSettings() {
|
12
|
+
return this.httpService
|
13
|
+
.api({
|
14
|
+
url: `${this.SERVICE_URL}`,
|
15
|
+
method: 'get',
|
16
|
+
})
|
17
|
+
.pipe(map((settings) => settings.map(setting => ConfigurationSettingsDTO.fromDTO(setting))));
|
18
|
+
}
|
19
|
+
fetchSetting(settingsKey) {
|
20
|
+
return this.httpService
|
21
|
+
.api({
|
22
|
+
url: `${this.SERVICE_URL}/byKey/${settingsKey}`,
|
23
|
+
method: 'get',
|
24
|
+
})
|
25
|
+
.pipe(map((setting) => ConfigurationSettingsDTO.fromDTO(setting, settingsKey)));
|
26
|
+
}
|
27
|
+
createSetting(setting) {
|
28
|
+
const request = ConfigurationSettingsDTO.toDTO(setting);
|
29
|
+
return this.httpService.api({
|
30
|
+
url: `${this.SERVICE_URL}`,
|
31
|
+
method: 'post',
|
32
|
+
body: Object.assign({}, request),
|
33
|
+
});
|
34
|
+
}
|
35
|
+
updateSetting(setting) {
|
36
|
+
const request = ConfigurationSettingsDTO.toDTO(setting);
|
37
|
+
return this.httpService.api({
|
38
|
+
url: `${this.SERVICE_URL}/${request.id}`,
|
39
|
+
method: 'put',
|
40
|
+
body: Object.assign({}, request),
|
41
|
+
});
|
42
|
+
}
|
43
|
+
removeSetting(setting) {
|
44
|
+
const request = ConfigurationSettingsDTO.toDTO(setting);
|
45
|
+
return this.httpService.api({
|
46
|
+
url: `${this.SERVICE_URL}/${request.id}`,
|
47
|
+
method: 'delete',
|
48
|
+
});
|
49
|
+
}
|
50
|
+
restoreSetting(settingId) {
|
51
|
+
return this.httpService.api({
|
52
|
+
url: `${this.SERVICE_URL}/${settingId}/restore`,
|
53
|
+
method: 'patch',
|
54
|
+
});
|
55
|
+
}
|
56
|
+
clear(name) {
|
57
|
+
return this.httpService
|
58
|
+
.api({
|
59
|
+
method: 'get',
|
60
|
+
url: '/cache/evict/' + name
|
61
|
+
});
|
62
|
+
}
|
63
|
+
}
|
64
|
+
ConfigurationSettingsApiService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: ConfigurationSettingsApiService, deps: [{ token: i1.BaseHttpService }], target: i0.ɵɵFactoryTarget.Injectable });
|
65
|
+
ConfigurationSettingsApiService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: ConfigurationSettingsApiService });
|
66
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: ConfigurationSettingsApiService, decorators: [{
|
67
|
+
type: Injectable
|
68
|
+
}], ctorParameters: function () { return [{ type: i1.BaseHttpService }]; } });
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlndXJhdGlvbi1zZXR0aW5ncy1hcGkuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYXBpL3NyYy9saWIvc2VydmljZXMvY29uZmlndXJhdGlvbi1zZXR0aW5ncy1hcGkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRzNDLE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyQyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQzs7O0FBR3JGLE1BQU0sT0FBTywrQkFBK0I7SUFHMUMsWUFBb0IsV0FBNEI7UUFBNUIsZ0JBQVcsR0FBWCxXQUFXLENBQWlCO1FBRi9CLGdCQUFXLEdBQUcseUJBQXlCLENBQUM7SUFFTixDQUFDO0lBRXBELGFBQWE7UUFDWCxPQUFPLElBQUksQ0FBQyxXQUFXO2FBQ3BCLEdBQUcsQ0FBNkI7WUFDL0IsR0FBRyxFQUFFLEdBQUcsSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUMxQixNQUFNLEVBQUUsS0FBSztTQUNkLENBQUM7YUFDRCxJQUFJLENBQ0gsR0FBRyxDQUFDLENBQUMsUUFBb0MsRUFBRSxFQUFFLENBQzNDLFFBQVEsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyx3QkFBd0IsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FDbkUsQ0FDRixDQUFDO0lBQ04sQ0FBQztJQUVELFlBQVksQ0FBQyxXQUFtQjtRQUM5QixPQUFPLElBQUksQ0FBQyxXQUFXO2FBQ3BCLEdBQUcsQ0FBMkI7WUFDN0IsR0FBRyxFQUFFLEdBQUcsSUFBSSxDQUFDLFdBQVcsVUFBVSxXQUFXLEVBQUU7WUFDL0MsTUFBTSxFQUFFLEtBQUs7U0FDZCxDQUFDO2FBQ0QsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE9BQWlDLEVBQUUsRUFBRSxDQUFDLHdCQUF3QixDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQzlHLENBQUM7SUFFRCxhQUFhLENBQUMsT0FBOEI7UUFDMUMsTUFBTSxPQUFPLEdBQUcsd0JBQXdCLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBRXhELE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUM7WUFDMUIsR0FBRyxFQUFFLEdBQUcsSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUMxQixNQUFNLEVBQUUsTUFBTTtZQUNkLElBQUksb0JBQ0MsT0FBTyxDQUNYO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELGFBQWEsQ0FBQyxPQUE4QjtRQUMxQyxNQUFNLE9BQU8sR0FBRyx3QkFBd0IsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFeEQsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQztZQUMxQixHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsV0FBVyxJQUFJLE9BQU8sQ0FBQyxFQUFFLEVBQUU7WUFDeEMsTUFBTSxFQUFFLEtBQUs7WUFDYixJQUFJLG9CQUNDLE9BQU8sQ0FDWDtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxhQUFhLENBQUMsT0FBOEI7UUFDMUMsTUFBTSxPQUFPLEdBQUcsd0JBQXdCLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBRXhELE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUM7WUFDMUIsR0FBRyxFQUFFLEdBQUcsSUFBSSxDQUFDLFdBQVcsSUFBSSxPQUFPLENBQUMsRUFBRSxFQUFFO1lBQ3hDLE1BQU0sRUFBRSxRQUFRO1NBQ2pCLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxjQUFjLENBQUMsU0FBaUI7UUFDOUIsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQztZQUMxQixHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsV0FBVyxJQUFJLFNBQVMsVUFBVTtZQUMvQyxNQUFNLEVBQUUsT0FBTztTQUNoQixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsS0FBSyxDQUFDLElBQTZCO1FBQ2pDLE9BQU8sSUFBSSxDQUFDLFdBQVc7YUFDcEIsR0FBRyxDQUFDO1lBQ0gsTUFBTSxFQUFFLEtBQUs7WUFDYixHQUFHLEVBQUUsZUFBZSxHQUFHLElBQUk7U0FDNUIsQ0FBQyxDQUFDO0lBQ1AsQ0FBQzs7NkhBekVVLCtCQUErQjtpSUFBL0IsK0JBQStCOzRGQUEvQiwrQkFBK0I7a0JBRDNDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCYXNlSHR0cFNlcnZpY2UsIENvbmZpZ3VyYXRpb25TZXR0aW5ncywgRGF0YUFkbWluaXN0cmF0aW9uRmllbGQgfSBmcm9tICdAdmVsb2NlL2NvcmUnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgbWFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuaW1wb3J0IHsgQ29uZmlndXJhdGlvblNldHRpbmdzRFRPIH0gZnJvbSAnLi4vdHlwZXMvY29uZmlndXJhdGlvbi1zZXR0aW5ncy1kdG8udHlwZXMnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgQ29uZmlndXJhdGlvblNldHRpbmdzQXBpU2VydmljZSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgU0VSVklDRV9VUkwgPSAnL2NvbmZpZ3VyYXRpb24tc2V0dGluZ3MnO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgaHR0cFNlcnZpY2U6IEJhc2VIdHRwU2VydmljZSkge31cblxuICBmZXRjaFNldHRpbmdzKCk6IE9ic2VydmFibGU8Q29uZmlndXJhdGlvblNldHRpbmdzW10+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwU2VydmljZVxuICAgICAgLmFwaTxDb25maWd1cmF0aW9uU2V0dGluZ3NEVE9bXT4oe1xuICAgICAgICB1cmw6IGAke3RoaXMuU0VSVklDRV9VUkx9YCxcbiAgICAgICAgbWV0aG9kOiAnZ2V0JyxcbiAgICAgIH0pXG4gICAgICAucGlwZShcbiAgICAgICAgbWFwKChzZXR0aW5nczogQ29uZmlndXJhdGlvblNldHRpbmdzRFRPW10pID0+XG4gICAgICAgICAgc2V0dGluZ3MubWFwKHNldHRpbmcgPT4gQ29uZmlndXJhdGlvblNldHRpbmdzRFRPLmZyb21EVE8oc2V0dGluZykpLFxuICAgICAgICApLFxuICAgICAgKTtcbiAgfVxuXG4gIGZldGNoU2V0dGluZyhzZXR0aW5nc0tleTogc3RyaW5nKTogT2JzZXJ2YWJsZTxDb25maWd1cmF0aW9uU2V0dGluZ3M+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwU2VydmljZVxuICAgICAgLmFwaTxDb25maWd1cmF0aW9uU2V0dGluZ3NEVE8+KHtcbiAgICAgICAgdXJsOiBgJHt0aGlzLlNFUlZJQ0VfVVJMfS9ieUtleS8ke3NldHRpbmdzS2V5fWAsXG4gICAgICAgIG1ldGhvZDogJ2dldCcsXG4gICAgICB9KVxuICAgICAgLnBpcGUobWFwKChzZXR0aW5nOiBDb25maWd1cmF0aW9uU2V0dGluZ3NEVE8pID0+IENvbmZpZ3VyYXRpb25TZXR0aW5nc0RUTy5mcm9tRFRPKHNldHRpbmcsIHNldHRpbmdzS2V5KSkpO1xuICB9XG5cbiAgY3JlYXRlU2V0dGluZyhzZXR0aW5nOiBDb25maWd1cmF0aW9uU2V0dGluZ3MpOiBPYnNlcnZhYmxlPENvbmZpZ3VyYXRpb25TZXR0aW5ncz4ge1xuICAgIGNvbnN0IHJlcXVlc3QgPSBDb25maWd1cmF0aW9uU2V0dGluZ3NEVE8udG9EVE8oc2V0dGluZyk7XG5cbiAgICByZXR1cm4gdGhpcy5odHRwU2VydmljZS5hcGkoe1xuICAgICAgdXJsOiBgJHt0aGlzLlNFUlZJQ0VfVVJMfWAsXG4gICAgICBtZXRob2Q6ICdwb3N0JyxcbiAgICAgIGJvZHk6IHtcbiAgICAgICAgLi4ucmVxdWVzdCxcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cblxuICB1cGRhdGVTZXR0aW5nKHNldHRpbmc6IENvbmZpZ3VyYXRpb25TZXR0aW5ncyk6IE9ic2VydmFibGU8Q29uZmlndXJhdGlvblNldHRpbmdzPiB7XG4gICAgY29uc3QgcmVxdWVzdCA9IENvbmZpZ3VyYXRpb25TZXR0aW5nc0RUTy50b0RUTyhzZXR0aW5nKTtcblxuICAgIHJldHVybiB0aGlzLmh0dHBTZXJ2aWNlLmFwaSh7XG4gICAgICB1cmw6IGAke3RoaXMuU0VSVklDRV9VUkx9LyR7cmVxdWVzdC5pZH1gLFxuICAgICAgbWV0aG9kOiAncHV0JyxcbiAgICAgIGJvZHk6IHtcbiAgICAgICAgLi4ucmVxdWVzdCxcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cblxuICByZW1vdmVTZXR0aW5nKHNldHRpbmc6IENvbmZpZ3VyYXRpb25TZXR0aW5ncyk6IE9ic2VydmFibGU8Q29uZmlndXJhdGlvblNldHRpbmdzPiB7XG4gICAgY29uc3QgcmVxdWVzdCA9IENvbmZpZ3VyYXRpb25TZXR0aW5nc0RUTy50b0RUTyhzZXR0aW5nKTtcblxuICAgIHJldHVybiB0aGlzLmh0dHBTZXJ2aWNlLmFwaSh7XG4gICAgICB1cmw6IGAke3RoaXMuU0VSVklDRV9VUkx9LyR7cmVxdWVzdC5pZH1gLFxuICAgICAgbWV0aG9kOiAnZGVsZXRlJyxcbiAgICB9KTtcbiAgfVxuXG4gIHJlc3RvcmVTZXR0aW5nKHNldHRpbmdJZDogc3RyaW5nKSB7XG4gICAgcmV0dXJuIHRoaXMuaHR0cFNlcnZpY2UuYXBpKHtcbiAgICAgIHVybDogYCR7dGhpcy5TRVJWSUNFX1VSTH0vJHtzZXR0aW5nSWR9L3Jlc3RvcmVgLFxuICAgICAgbWV0aG9kOiAncGF0Y2gnLFxuICAgIH0pO1xuICB9XG5cbiAgY2xlYXIobmFtZTogRGF0YUFkbWluaXN0cmF0aW9uRmllbGQpOiBPYnNlcnZhYmxlPHZvaWQ+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwU2VydmljZVxuICAgICAgLmFwaSh7XG4gICAgICAgIG1ldGhvZDogJ2dldCcsXG4gICAgICAgIHVybDogJy9jYWNoZS9ldmljdC8nICsgbmFtZVxuICAgICAgfSk7XG4gIH1cbn1cbiJdfQ==
|
@@ -0,0 +1,26 @@
|
|
1
|
+
import { Injectable } from '@angular/core';
|
2
|
+
import { ConfigurationContextMode } from '@veloce/core';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
import * as i1 from "@veloce/core";
|
5
|
+
export class ContextApiService {
|
6
|
+
constructor(httpService) {
|
7
|
+
this.httpService = httpService;
|
8
|
+
this.SERVICE_URL = '/context';
|
9
|
+
}
|
10
|
+
getContext(headerId, mode) {
|
11
|
+
return this.httpService.api({
|
12
|
+
method: 'post',
|
13
|
+
body: {
|
14
|
+
headerId: headerId,
|
15
|
+
contextMode: ConfigurationContextMode[mode],
|
16
|
+
},
|
17
|
+
url: `${this.SERVICE_URL}`,
|
18
|
+
});
|
19
|
+
}
|
20
|
+
}
|
21
|
+
ContextApiService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: ContextApiService, deps: [{ token: i1.BaseHttpService }], target: i0.ɵɵFactoryTarget.Injectable });
|
22
|
+
ContextApiService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: ContextApiService });
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: ContextApiService, decorators: [{
|
24
|
+
type: Injectable
|
25
|
+
}], ctorParameters: function () { return [{ type: i1.BaseHttpService }]; } });
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC1hcGkuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYXBpL3NyYy9saWIvc2VydmljZXMvY29udGV4dC1hcGkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBeUMsd0JBQXdCLEVBQUUsTUFBTSxjQUFjLENBQUM7OztBQUkvRixNQUFNLE9BQU8saUJBQWlCO0lBRzVCLFlBQW9CLFdBQTRCO1FBQTVCLGdCQUFXLEdBQVgsV0FBVyxDQUFpQjtRQUYvQixnQkFBVyxHQUFHLFVBQVUsQ0FBQztJQUVTLENBQUM7SUFFcEQsVUFBVSxDQUFDLFFBQWdCLEVBQUUsSUFBOEI7UUFDekQsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQztZQUMxQixNQUFNLEVBQUUsTUFBTTtZQUNkLElBQUksRUFBRTtnQkFDSixRQUFRLEVBQUUsUUFBUTtnQkFDbEIsV0FBVyxFQUFFLHdCQUF3QixDQUFDLElBQUksQ0FBQzthQUM1QztZQUNELEdBQUcsRUFBRSxHQUFHLElBQUksQ0FBQyxXQUFXLEVBQUU7U0FDM0IsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7K0dBZFUsaUJBQWlCO21IQUFqQixpQkFBaUI7NEZBQWpCLGlCQUFpQjtrQkFEN0IsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJhc2VIdHRwU2VydmljZSwgQ29uZmlndXJhdGlvbkNvbnRleHQsIENvbmZpZ3VyYXRpb25Db250ZXh0TW9kZSB9IGZyb20gJ0B2ZWxvY2UvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBDb250ZXh0QXBpU2VydmljZSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgU0VSVklDRV9VUkwgPSAnL2NvbnRleHQnO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgaHR0cFNlcnZpY2U6IEJhc2VIdHRwU2VydmljZSkge31cblxuICBnZXRDb250ZXh0KGhlYWRlcklkOiBzdHJpbmcsIG1vZGU6IENvbmZpZ3VyYXRpb25Db250ZXh0TW9kZSk6IE9ic2VydmFibGU8Q29uZmlndXJhdGlvbkNvbnRleHQ+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwU2VydmljZS5hcGkoe1xuICAgICAgbWV0aG9kOiAncG9zdCcsXG4gICAgICBib2R5OiB7XG4gICAgICAgIGhlYWRlcklkOiBoZWFkZXJJZCxcbiAgICAgICAgY29udGV4dE1vZGU6IENvbmZpZ3VyYXRpb25Db250ZXh0TW9kZVttb2RlXSxcbiAgICAgIH0sXG4gICAgICB1cmw6IGAke3RoaXMuU0VSVklDRV9VUkx9YCxcbiAgICB9KTtcbiAgfVxufVxuIl19
|
@@ -0,0 +1,65 @@
|
|
1
|
+
import { Injectable } from '@angular/core';
|
2
|
+
import { map, tap } from 'rxjs/operators';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
import * as i1 from "@veloce/core";
|
5
|
+
export class DocumentAttachmentApiService {
|
6
|
+
constructor(httpService, fileDownloadService) {
|
7
|
+
this.httpService = httpService;
|
8
|
+
this.fileDownloadService = fileDownloadService;
|
9
|
+
}
|
10
|
+
getAttachments(searchRequest) {
|
11
|
+
return this.httpService.api({
|
12
|
+
url: '/attachments/search',
|
13
|
+
method: 'post',
|
14
|
+
body: searchRequest,
|
15
|
+
});
|
16
|
+
}
|
17
|
+
createAttachment(attachment, file, reportProgress) {
|
18
|
+
const formData = new FormData();
|
19
|
+
if (file) {
|
20
|
+
formData.append('file', file, file.name);
|
21
|
+
}
|
22
|
+
formData.append('attachment', new Blob([JSON.stringify(attachment)], {
|
23
|
+
type: 'application/json',
|
24
|
+
}));
|
25
|
+
return this.httpService.upload({
|
26
|
+
url: `/attachments`,
|
27
|
+
body: formData,
|
28
|
+
method: 'post',
|
29
|
+
observe: reportProgress ? 'events' : undefined,
|
30
|
+
reportProgress,
|
31
|
+
});
|
32
|
+
}
|
33
|
+
updateAttachment(id, attachment) {
|
34
|
+
return this.httpService.api({
|
35
|
+
url: `/attachments/${id}`,
|
36
|
+
body: attachment,
|
37
|
+
method: 'put',
|
38
|
+
});
|
39
|
+
}
|
40
|
+
getAttachmentFile(id, isPreventDownload) {
|
41
|
+
return this.httpService
|
42
|
+
.api({
|
43
|
+
url: `/attachments/${id}/file`,
|
44
|
+
responseType: isPreventDownload ? 'arraybuffer' : 'blob',
|
45
|
+
observe: isPreventDownload ? 'body' : 'response',
|
46
|
+
})
|
47
|
+
.pipe(tap(response => {
|
48
|
+
if (!isPreventDownload) {
|
49
|
+
this.fileDownloadService.processDownload(response);
|
50
|
+
}
|
51
|
+
}), map(response => (isPreventDownload ? new Blob([response.body || response]) : response.body || response)));
|
52
|
+
}
|
53
|
+
removeAttachment(id) {
|
54
|
+
return this.httpService.api({
|
55
|
+
url: `/attachments/${id}`,
|
56
|
+
method: 'delete',
|
57
|
+
});
|
58
|
+
}
|
59
|
+
}
|
60
|
+
DocumentAttachmentApiService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: DocumentAttachmentApiService, deps: [{ token: i1.BaseHttpService }, { token: i1.FileDownloadService }], target: i0.ɵɵFactoryTarget.Injectable });
|
61
|
+
DocumentAttachmentApiService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: DocumentAttachmentApiService });
|
62
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: DocumentAttachmentApiService, decorators: [{
|
63
|
+
type: Injectable
|
64
|
+
}], ctorParameters: function () { return [{ type: i1.BaseHttpService }, { type: i1.FileDownloadService }]; } });
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9jdW1lbnQtYXR0YWNobWVudC1hcGkuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYXBpL3NyYy9saWIvc2VydmljZXMvZG9jdW1lbnQtYXR0YWNobWVudC1hcGkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBUTNDLE9BQU8sRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQUcxQyxNQUFNLE9BQU8sNEJBQTRCO0lBQ3ZDLFlBQW9CLFdBQTRCLEVBQVUsbUJBQXdDO1FBQTlFLGdCQUFXLEdBQVgsV0FBVyxDQUFpQjtRQUFVLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBcUI7SUFBRyxDQUFDO0lBRXRHLGNBQWMsQ0FBQyxhQUE4QztRQUMzRCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDO1lBQzFCLEdBQUcsRUFBRSxxQkFBcUI7WUFDMUIsTUFBTSxFQUFFLE1BQU07WUFDZCxJQUFJLEVBQUUsYUFBYTtTQUNwQixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsZ0JBQWdCLENBQ2QsVUFBOEIsRUFDOUIsSUFBVyxFQUNYLGNBQXdCO1FBRXhCLE1BQU0sUUFBUSxHQUFhLElBQUksUUFBUSxFQUFFLENBQUM7UUFFMUMsSUFBSSxJQUFJLEVBQUU7WUFDUixRQUFRLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQzFDO1FBRUQsUUFBUSxDQUFDLE1BQU0sQ0FDYixZQUFZLEVBQ1osSUFBSSxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxDQUFDLEVBQUU7WUFDckMsSUFBSSxFQUFFLGtCQUFrQjtTQUN6QixDQUFDLENBQ0gsQ0FBQztRQUVGLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUM7WUFDN0IsR0FBRyxFQUFFLGNBQWM7WUFDbkIsSUFBSSxFQUFFLFFBQVE7WUFDZCxNQUFNLEVBQUUsTUFBTTtZQUNkLE9BQU8sRUFBRSxjQUFjLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsU0FBUztZQUM5QyxjQUFjO1NBQ2YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELGdCQUFnQixDQUFDLEVBQVUsRUFBRSxVQUE4QjtRQUN6RCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDO1lBQzFCLEdBQUcsRUFBRSxnQkFBZ0IsRUFBRSxFQUFFO1lBQ3pCLElBQUksRUFBRSxVQUFVO1lBQ2hCLE1BQU0sRUFBRSxLQUFLO1NBQ2QsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQVUsRUFBRSxpQkFBMkI7UUFDdkQsT0FBTyxJQUFJLENBQUMsV0FBVzthQUNwQixHQUFHLENBQUM7WUFDSCxHQUFHLEVBQUUsZ0JBQWdCLEVBQUUsT0FBTztZQUM5QixZQUFZLEVBQUUsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsTUFBTTtZQUN4RCxPQUFPLEVBQUUsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsVUFBVTtTQUNqRCxDQUFDO2FBQ0QsSUFBSSxDQUNILEdBQUcsQ0FBQyxRQUFRLENBQUMsRUFBRTtZQUNiLElBQUksQ0FBQyxpQkFBaUIsRUFBRTtnQkFDdEIsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGVBQWUsQ0FBQyxRQUFRLENBQUMsQ0FBQzthQUNwRDtRQUNILENBQUMsQ0FBQyxFQUNGLEdBQUcsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLElBQUksSUFBSSxDQUFDLENBQUMsUUFBUSxDQUFDLElBQUksSUFBSSxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsSUFBSSxJQUFJLFFBQVEsQ0FBQyxDQUFDLENBQ3pHLENBQUM7SUFDTixDQUFDO0lBRUQsZ0JBQWdCLENBQUMsRUFBVTtRQUN6QixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDO1lBQzFCLEdBQUcsRUFBRSxnQkFBZ0IsRUFBRSxFQUFFO1lBQ3pCLE1BQU0sRUFBRSxRQUFRO1NBQ2pCLENBQUMsQ0FBQztJQUNMLENBQUM7OzBIQXBFVSw0QkFBNEI7OEhBQTVCLDRCQUE0Qjs0RkFBNUIsNEJBQTRCO2tCQUR4QyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgQmFzZUh0dHBTZXJ2aWNlLFxuICBGaWxlRG93bmxvYWRTZXJ2aWNlLFxuICBUZW1wbGF0ZUF0dGFjaG1lbnQsXG4gIFRlbXBsYXRlQXR0YWNobWVudFNlYXJjaFJlcXVlc3QsXG59IGZyb20gJ0B2ZWxvY2UvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBtYXAsIHRhcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIERvY3VtZW50QXR0YWNobWVudEFwaVNlcnZpY2Uge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGh0dHBTZXJ2aWNlOiBCYXNlSHR0cFNlcnZpY2UsIHByaXZhdGUgZmlsZURvd25sb2FkU2VydmljZTogRmlsZURvd25sb2FkU2VydmljZSkge31cblxuICBnZXRBdHRhY2htZW50cyhzZWFyY2hSZXF1ZXN0OiBUZW1wbGF0ZUF0dGFjaG1lbnRTZWFyY2hSZXF1ZXN0KTogT2JzZXJ2YWJsZTxUZW1wbGF0ZUF0dGFjaG1lbnRbXT4ge1xuICAgIHJldHVybiB0aGlzLmh0dHBTZXJ2aWNlLmFwaSh7XG4gICAgICB1cmw6ICcvYXR0YWNobWVudHMvc2VhcmNoJyxcbiAgICAgIG1ldGhvZDogJ3Bvc3QnLFxuICAgICAgYm9keTogc2VhcmNoUmVxdWVzdCxcbiAgICB9KTtcbiAgfVxuXG4gIGNyZWF0ZUF0dGFjaG1lbnQoXG4gICAgYXR0YWNobWVudDogVGVtcGxhdGVBdHRhY2htZW50LFxuICAgIGZpbGU/OiBGaWxlLFxuICAgIHJlcG9ydFByb2dyZXNzPzogYm9vbGVhbixcbiAgKTogT2JzZXJ2YWJsZTxUZW1wbGF0ZUF0dGFjaG1lbnQ+IHtcbiAgICBjb25zdCBmb3JtRGF0YTogRm9ybURhdGEgPSBuZXcgRm9ybURhdGEoKTtcblxuICAgIGlmIChmaWxlKSB7XG4gICAgICBmb3JtRGF0YS5hcHBlbmQoJ2ZpbGUnLCBmaWxlLCBmaWxlLm5hbWUpO1xuICAgIH1cblxuICAgIGZvcm1EYXRhLmFwcGVuZChcbiAgICAgICdhdHRhY2htZW50JyxcbiAgICAgIG5ldyBCbG9iKFtKU09OLnN0cmluZ2lmeShhdHRhY2htZW50KV0sIHtcbiAgICAgICAgdHlwZTogJ2FwcGxpY2F0aW9uL2pzb24nLFxuICAgICAgfSksXG4gICAgKTtcblxuICAgIHJldHVybiB0aGlzLmh0dHBTZXJ2aWNlLnVwbG9hZCh7XG4gICAgICB1cmw6IGAvYXR0YWNobWVudHNgLFxuICAgICAgYm9keTogZm9ybURhdGEsXG4gICAgICBtZXRob2Q6ICdwb3N0JyxcbiAgICAgIG9ic2VydmU6IHJlcG9ydFByb2dyZXNzID8gJ2V2ZW50cycgOiB1bmRlZmluZWQsXG4gICAgICByZXBvcnRQcm9ncmVzcyxcbiAgICB9KTtcbiAgfVxuXG4gIHVwZGF0ZUF0dGFjaG1lbnQoaWQ6IHN0cmluZywgYXR0YWNobWVudDogVGVtcGxhdGVBdHRhY2htZW50KTogT2JzZXJ2YWJsZTxUZW1wbGF0ZUF0dGFjaG1lbnQ+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwU2VydmljZS5hcGkoe1xuICAgICAgdXJsOiBgL2F0dGFjaG1lbnRzLyR7aWR9YCxcbiAgICAgIGJvZHk6IGF0dGFjaG1lbnQsXG4gICAgICBtZXRob2Q6ICdwdXQnLFxuICAgIH0pO1xuICB9XG5cbiAgZ2V0QXR0YWNobWVudEZpbGUoaWQ6IHN0cmluZywgaXNQcmV2ZW50RG93bmxvYWQ/OiBib29sZWFuKTogT2JzZXJ2YWJsZTxhbnk+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwU2VydmljZVxuICAgICAgLmFwaSh7XG4gICAgICAgIHVybDogYC9hdHRhY2htZW50cy8ke2lkfS9maWxlYCxcbiAgICAgICAgcmVzcG9uc2VUeXBlOiBpc1ByZXZlbnREb3dubG9hZCA/ICdhcnJheWJ1ZmZlcicgOiAnYmxvYicsXG4gICAgICAgIG9ic2VydmU6IGlzUHJldmVudERvd25sb2FkID8gJ2JvZHknIDogJ3Jlc3BvbnNlJyxcbiAgICAgIH0pXG4gICAgICAucGlwZShcbiAgICAgICAgdGFwKHJlc3BvbnNlID0+IHtcbiAgICAgICAgICBpZiAoIWlzUHJldmVudERvd25sb2FkKSB7XG4gICAgICAgICAgICB0aGlzLmZpbGVEb3dubG9hZFNlcnZpY2UucHJvY2Vzc0Rvd25sb2FkKHJlc3BvbnNlKTtcbiAgICAgICAgICB9XG4gICAgICAgIH0pLFxuICAgICAgICBtYXAocmVzcG9uc2UgPT4gKGlzUHJldmVudERvd25sb2FkID8gbmV3IEJsb2IoW3Jlc3BvbnNlLmJvZHkgfHwgcmVzcG9uc2VdKSA6IHJlc3BvbnNlLmJvZHkgfHwgcmVzcG9uc2UpKSxcbiAgICAgICk7XG4gIH1cblxuICByZW1vdmVBdHRhY2htZW50KGlkOiBzdHJpbmcpOiBPYnNlcnZhYmxlPHVua25vd24+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwU2VydmljZS5hcGkoe1xuICAgICAgdXJsOiBgL2F0dGFjaG1lbnRzLyR7aWR9YCxcbiAgICAgIG1ldGhvZDogJ2RlbGV0ZScsXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
|
@@ -0,0 +1,278 @@
|
|
1
|
+
import { CurrencyPipe } from '@angular/common';
|
2
|
+
import { Injectable } from '@angular/core';
|
3
|
+
import { DocxTemplater, QuoteDraft, StringUtils, } from '@veloce/core';
|
4
|
+
import * as _ from 'lodash';
|
5
|
+
import * as 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 "@veloce/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
|
+
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
|
+
export class DocumentTemplatesApiService {
|
33
|
+
constructor(service, sfRepo, fileDownloadService, documentAttachmentService, http) {
|
34
|
+
this.service = service;
|
35
|
+
this.sfRepo = sfRepo;
|
36
|
+
this.fileDownloadService = fileDownloadService;
|
37
|
+
this.documentAttachmentService = documentAttachmentService;
|
38
|
+
this.http = http;
|
39
|
+
this.fallbackDocGenHost = 'https://dev-dp1.velocpq.com/docgen';
|
40
|
+
if (window.VELO_DOCGEN_API) {
|
41
|
+
this.docGenHost = window.VELO_DOCGEN_API;
|
42
|
+
}
|
43
|
+
else {
|
44
|
+
console.log(`window.VELO_DOCGEN_API not set, will use fallback "${this.fallbackDocGenHost}"`);
|
45
|
+
this.docGenHost = this.fallbackDocGenHost;
|
46
|
+
}
|
47
|
+
}
|
48
|
+
getTemplates(tag) {
|
49
|
+
return this.service.api({
|
50
|
+
url: '/templates',
|
51
|
+
method: 'get',
|
52
|
+
params: Object.assign({}, (tag && { tag })),
|
53
|
+
});
|
54
|
+
}
|
55
|
+
upsertTemplate(template, file, reportProgress) {
|
56
|
+
const formData = new FormData();
|
57
|
+
if (file) {
|
58
|
+
formData.append('file', file, file.name);
|
59
|
+
}
|
60
|
+
formData.append('template', new Blob([JSON.stringify(template)], {
|
61
|
+
type: 'application/json',
|
62
|
+
}));
|
63
|
+
return this.service.upload({
|
64
|
+
url: `/templates` + ((template.id && `/${template.id}`) || ''),
|
65
|
+
body: formData,
|
66
|
+
method: template.id ? 'put' : 'post',
|
67
|
+
reportProgress,
|
68
|
+
});
|
69
|
+
}
|
70
|
+
removeTemplate(id) {
|
71
|
+
return this.service.api({
|
72
|
+
url: '/templates' + id,
|
73
|
+
method: 'delete',
|
74
|
+
});
|
75
|
+
}
|
76
|
+
cloneTemplate(id) {
|
77
|
+
return this.service.api({
|
78
|
+
url: '/templates/clone/' + id,
|
79
|
+
method: 'post',
|
80
|
+
});
|
81
|
+
}
|
82
|
+
generateDocumentData(template, object, params) {
|
83
|
+
var _a, _b, _c, _d;
|
84
|
+
const shouldPreventDownload = params === null || params === void 0 ? void 0 : params.shouldPreventDownload;
|
85
|
+
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;
|
86
|
+
if (!useLocalDataGeneration && object instanceof QuoteDraft) {
|
87
|
+
return this.generate('/templates/generate-data', { template, quote: object }, shouldPreventDownload, shouldPreventDownload ? 'json' : 'blob');
|
88
|
+
}
|
89
|
+
const allQueries = [...((_c = template === null || template === void 0 ? void 0 : template.queries) !== null && _c !== void 0 ? _c : [])];
|
90
|
+
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) || {};
|
91
|
+
const accountId = properties === null || properties === void 0 ? void 0 : properties.AccountId;
|
92
|
+
const userId = properties === null || properties === void 0 ? void 0 : properties.UserId;
|
93
|
+
if (accountId) {
|
94
|
+
allQueries.push({
|
95
|
+
queryName: 'QuoteAccountQuery',
|
96
|
+
objectName: 'Account',
|
97
|
+
resultObjectName: 'account',
|
98
|
+
statement: `Id ='${accountId}'`,
|
99
|
+
fields: [],
|
100
|
+
});
|
101
|
+
}
|
102
|
+
if (userId) {
|
103
|
+
allQueries.push({
|
104
|
+
queryName: 'QuoteUserQuery',
|
105
|
+
objectName: 'User',
|
106
|
+
resultObjectName: 'agent',
|
107
|
+
statement: `Id ='${userId}'`,
|
108
|
+
fields: [],
|
109
|
+
});
|
110
|
+
}
|
111
|
+
const queries = allQueries.map(query => this.queryObject(query, { properties })) || [];
|
112
|
+
return forkJoin([...queries])
|
113
|
+
.pipe(defaultIfEmpty([]))
|
114
|
+
.pipe(map(results => {
|
115
|
+
var _a, _b, _c, _d;
|
116
|
+
const queriesResult = _.chain(results)
|
117
|
+
.reduce((acc, r) => {
|
118
|
+
if (r) {
|
119
|
+
return Object.assign(Object.assign({}, acc), r);
|
120
|
+
}
|
121
|
+
return acc;
|
122
|
+
}, {})
|
123
|
+
.value();
|
124
|
+
const templateProperties = ((template === null || template === void 0 ? void 0 : template.properties) || []).reduce((trunk, { name, value }) => {
|
125
|
+
return Object.assign(Object.assign({}, trunk), { [name]: mapBooleanIfAplicable(value) });
|
126
|
+
}, {});
|
127
|
+
const data = Object.assign(Object.assign(Object.assign({}, (typeof object === 'object' ? object : { object })), queriesResult), templateProperties);
|
128
|
+
if (template.script && template.script.trim().length) {
|
129
|
+
const currencyFormat = ((_b = (_a = template.properties) === null || _a === void 0 ? void 0 : _a.find(({ name }) => name === 'currencyFormat')) === null || _b === void 0 ? void 0 : _b.value) || '1.2-2';
|
130
|
+
const dateFormat = ((_d = (_c = template.properties) === null || _c === void 0 ? void 0 : _c.find(({ name }) => name === 'dateFormat')) === null || _d === void 0 ? void 0 : _d.value) || 'D/MMM/YYYY';
|
131
|
+
const formatDate = (value) => {
|
132
|
+
return value ? moment(value).format(dateFormat) : value;
|
133
|
+
};
|
134
|
+
const transform = new Function(`return ${template.script}`)();
|
135
|
+
const transformedData = transform(Object.assign(Object.assign({}, data), { utils: {
|
136
|
+
lodash: _,
|
137
|
+
currency: (value) => new CurrencyPipe('en-US').transform(value, 'USD', 'symbol', currencyFormat),
|
138
|
+
date: formatDate,
|
139
|
+
}, ToDay: formatDate(Date.now()) }));
|
140
|
+
if (!shouldPreventDownload) {
|
141
|
+
const blob = new Blob([JSON.stringify(transformedData)]);
|
142
|
+
this.fileDownloadService.processDownload(blob, 'data.json');
|
143
|
+
}
|
144
|
+
return transformedData;
|
145
|
+
}
|
146
|
+
return data;
|
147
|
+
}));
|
148
|
+
}
|
149
|
+
generateDocument(template, object, params = {}) {
|
150
|
+
const attachmentIds = (template.attachments || []).map(({ id }) => id).filter(Boolean);
|
151
|
+
const { shouldUseLocalDocxTemplater } = params;
|
152
|
+
return shouldUseLocalDocxTemplater && !(object instanceof QuoteDraft)
|
153
|
+
? this.generateDocumentNew(template, object, params)
|
154
|
+
: this.generateWithBackendDocxTemplater({ template, quote: object, attachmentIds, params });
|
155
|
+
}
|
156
|
+
generateDocumentNew(template, object, params = {}) {
|
157
|
+
const { attachToQuote, documentFormat, shouldPreventDownload } = params;
|
158
|
+
const file$ = this.service.api({
|
159
|
+
method: 'get',
|
160
|
+
url: `/templates/${template.id}/file`,
|
161
|
+
responseType: 'arraybuffer',
|
162
|
+
});
|
163
|
+
const attachmentIds = (template.attachments || []).map(({ id }) => id);
|
164
|
+
const attachments$ = attachmentIds.length
|
165
|
+
? attachmentIds.map(attachmentId => {
|
166
|
+
return this.documentAttachmentService.getAttachmentFile(attachmentId, true);
|
167
|
+
})
|
168
|
+
: [];
|
169
|
+
const data$ = this.generateDocumentData(template, object, Object.assign(Object.assign({}, params), { shouldPreventDownload: true }));
|
170
|
+
return zip(file$, data$, ...attachments$).pipe(switchMap(([file, data, ...attachments]) => {
|
171
|
+
var _a;
|
172
|
+
const d = DocxTemplater.generate(file, data);
|
173
|
+
const body = new FormData();
|
174
|
+
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) || {};
|
175
|
+
const documentName = (properties === null || properties === void 0 ? void 0 : properties.Name) || template.name;
|
176
|
+
// TODO: special CATO case. Refactor for a more generic approach
|
177
|
+
if (documentFormat === 'DOCX') {
|
178
|
+
this.fileDownloadService.processDownload(d, documentName);
|
179
|
+
return of(d);
|
180
|
+
}
|
181
|
+
attachments.forEach((attachment) => {
|
182
|
+
body.append('attachments', new Blob([attachment]));
|
183
|
+
});
|
184
|
+
body.append('orderform', d);
|
185
|
+
return this.http
|
186
|
+
.post(`${this.docGenHost}/documents/merge`, body, {
|
187
|
+
responseType: 'arraybuffer',
|
188
|
+
})
|
189
|
+
.pipe(switchMap((pdf) => {
|
190
|
+
const blob = new Blob([pdf]);
|
191
|
+
if (!shouldPreventDownload) {
|
192
|
+
this.fileDownloadService.processDownload(blob, `${documentName}.pdf`);
|
193
|
+
}
|
194
|
+
if (attachToQuote && object instanceof QuoteDraft) {
|
195
|
+
const formData = new FormData();
|
196
|
+
formData.append('file', blob, `${documentName}.pdf`);
|
197
|
+
return this.http.post(`${window['VELO_API']}/services/quotes/${object.quoteId}/attach-document`, formData, {
|
198
|
+
responseType: 'arraybuffer',
|
199
|
+
headers: {
|
200
|
+
Authorization: window['VELO_KEY'],
|
201
|
+
},
|
202
|
+
});
|
203
|
+
}
|
204
|
+
return of(blob);
|
205
|
+
}));
|
206
|
+
}));
|
207
|
+
}
|
208
|
+
getAttachments(searchRequest) {
|
209
|
+
return this.documentAttachmentService.getAttachments(searchRequest);
|
210
|
+
}
|
211
|
+
getAttachmentFile(id) {
|
212
|
+
return this.documentAttachmentService.getAttachmentFile(id);
|
213
|
+
}
|
214
|
+
createAttachment(attachment, file, reportProgress) {
|
215
|
+
return this.documentAttachmentService.createAttachment(attachment, file, reportProgress);
|
216
|
+
}
|
217
|
+
removeAttachment(id) {
|
218
|
+
return this.documentAttachmentService.removeAttachment(id);
|
219
|
+
}
|
220
|
+
downloadTemplateFile(id) {
|
221
|
+
return this.service
|
222
|
+
.api({
|
223
|
+
url: `/templates/${id}/file`,
|
224
|
+
responseType: 'blob',
|
225
|
+
observe: 'response',
|
226
|
+
})
|
227
|
+
.pipe(tap(response => {
|
228
|
+
this.fileDownloadService.processDownload(response);
|
229
|
+
}), map(response => response.body || response));
|
230
|
+
}
|
231
|
+
generateWithBackendDocxTemplater({ template, quote, attachmentIds, params, }) {
|
232
|
+
const { shouldPreventDownload } = params;
|
233
|
+
const nonEmptyParams = Object.keys(params || {})
|
234
|
+
.filter(k => params[k] !== undefined)
|
235
|
+
.reduce((obj, key) => {
|
236
|
+
obj[key] = params[key];
|
237
|
+
return obj;
|
238
|
+
}, {});
|
239
|
+
return this.generate(`/templates/${template.id}/generate`, { quote, attachments: attachmentIds }, Boolean(shouldPreventDownload), 'blob', nonEmptyParams, false);
|
240
|
+
}
|
241
|
+
generate(url, body, shouldPreventDownload, responseType, params, isUpload, reportProgress) {
|
242
|
+
const requestOptions = {
|
243
|
+
method: 'post',
|
244
|
+
url,
|
245
|
+
body,
|
246
|
+
reportProgress,
|
247
|
+
responseType,
|
248
|
+
observe: shouldPreventDownload ? 'body' : 'response',
|
249
|
+
params,
|
250
|
+
};
|
251
|
+
return (isUpload ? this.service.upload(requestOptions) : this.service.api(requestOptions)).pipe(tap(response => {
|
252
|
+
if (!shouldPreventDownload) {
|
253
|
+
this.fileDownloadService.processDownload(response);
|
254
|
+
}
|
255
|
+
}));
|
256
|
+
}
|
257
|
+
queryObject({ objectName, resultObjectName, fields, statement }, { properties }) {
|
258
|
+
var _a;
|
259
|
+
const patternLimit = /(\s*limit\s\d*)/i;
|
260
|
+
let limit = 1;
|
261
|
+
if (patternLimit.test(statement)) {
|
262
|
+
const limitStr = (_a = statement === null || statement === void 0 ? void 0 : statement.match(patternLimit)) === null || _a === void 0 ? void 0 : _a[1].trim().substring(5).trim();
|
263
|
+
if (limitStr) {
|
264
|
+
limit = Number.parseInt(limitStr, 10);
|
265
|
+
}
|
266
|
+
statement = statement.replace(patternLimit, '');
|
267
|
+
}
|
268
|
+
const resolvedStatement = StringUtils.fillPlaceholders(statement, properties, /:\s*(\w[\w\d_.]+)/i);
|
269
|
+
const searchRequest = Object.assign({ skip: 0, count: limit, rawCondition: resolvedStatement }, ((fields === null || fields === void 0 ? void 0 : fields.length) && !!fields[0] && { fields }));
|
270
|
+
return this.sfRepo.query(searchRequest, objectName).pipe(mapSfQueryResult(limit), map(value => ({ [resultObjectName]: value })));
|
271
|
+
}
|
272
|
+
}
|
273
|
+
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 });
|
274
|
+
DocumentTemplatesApiService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: DocumentTemplatesApiService });
|
275
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: DocumentTemplatesApiService, decorators: [{
|
276
|
+
type: Injectable
|
277
|
+
}], ctorParameters: function () { return [{ type: i1.BaseHttpService }, { type: i2.SalesforceApiService }, { type: i1.FileDownloadService }, { type: i3.DocumentAttachmentApiService }, { type: i4.HttpClient }]; } });
|
278
|
+
//# 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  cloneTemplate(id: string): Observable<DocumentTemplate> {\n    return this.service.api({\n      url: '/templates/clone/' + id,\n      method: 'post',\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"]}
|
@@ -0,0 +1,86 @@
|
|
1
|
+
import { Injectable } from '@angular/core';
|
2
|
+
import * as i0 from "@angular/core";
|
3
|
+
import * as i1 from "@veloce/core";
|
4
|
+
export class PriceApiService {
|
5
|
+
constructor(httpService) {
|
6
|
+
this.httpService = httpService;
|
7
|
+
this.SERVICE_URL = '/price';
|
8
|
+
}
|
9
|
+
calculateRuntime(request) {
|
10
|
+
return this.httpService.api({
|
11
|
+
method: 'post',
|
12
|
+
url: `${this.SERVICE_URL}/calculate-runtime`,
|
13
|
+
body: request,
|
14
|
+
});
|
15
|
+
}
|
16
|
+
calculate(request) {
|
17
|
+
return this.httpService.api({
|
18
|
+
method: 'post',
|
19
|
+
url: `${this.SERVICE_URL}/calculate`,
|
20
|
+
body: request,
|
21
|
+
});
|
22
|
+
// TODO: move outside API service
|
23
|
+
// .pipe(
|
24
|
+
// map(data => {
|
25
|
+
// if (data.context) {
|
26
|
+
// const context = this.contextService.resolveOrCreate();
|
27
|
+
// const patchedContext = {
|
28
|
+
// ...context,
|
29
|
+
// properties: {
|
30
|
+
// ...context.properties,
|
31
|
+
// ...data.context.properties,
|
32
|
+
// },
|
33
|
+
// };
|
34
|
+
// this.contextService.update(patchedContext);
|
35
|
+
// }
|
36
|
+
// return data;
|
37
|
+
// }),
|
38
|
+
// );
|
39
|
+
}
|
40
|
+
getPriceLists() {
|
41
|
+
return this.httpService.api({
|
42
|
+
method: 'get',
|
43
|
+
url: '/price-lists',
|
44
|
+
});
|
45
|
+
}
|
46
|
+
getPriceList(id) {
|
47
|
+
return this.httpService.api({
|
48
|
+
method: 'get',
|
49
|
+
url: `/price-lists/${id}`,
|
50
|
+
});
|
51
|
+
}
|
52
|
+
getSellingTermByEndDate(planId, offeringId, startDate, endDate, frequencyUnit, frequencyDuration) {
|
53
|
+
return this.httpService.api({
|
54
|
+
method: 'post',
|
55
|
+
url: `${this.SERVICE_URL}/selling-term-by-end-date`,
|
56
|
+
body: {
|
57
|
+
planId: planId,
|
58
|
+
offeringId: offeringId,
|
59
|
+
startDate: startDate,
|
60
|
+
endDate: endDate,
|
61
|
+
frequencyUnit: frequencyUnit,
|
62
|
+
frequencyDuration: frequencyDuration,
|
63
|
+
},
|
64
|
+
});
|
65
|
+
}
|
66
|
+
getSellingTermByTerm(planId, offeringId, startDate, term, frequencyUnit, frequencyDuration) {
|
67
|
+
return this.httpService.api({
|
68
|
+
method: 'post',
|
69
|
+
url: `${this.SERVICE_URL}/selling-term-by-term`,
|
70
|
+
body: {
|
71
|
+
planId: planId,
|
72
|
+
offeringId: offeringId,
|
73
|
+
startDate: startDate,
|
74
|
+
term: term,
|
75
|
+
frequencyUnit: frequencyUnit,
|
76
|
+
frequencyDuration: frequencyDuration,
|
77
|
+
},
|
78
|
+
});
|
79
|
+
}
|
80
|
+
}
|
81
|
+
PriceApiService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: PriceApiService, deps: [{ token: i1.BaseHttpService }], target: i0.ɵɵFactoryTarget.Injectable });
|
82
|
+
PriceApiService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: PriceApiService });
|
83
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: PriceApiService, decorators: [{
|
84
|
+
type: Injectable
|
85
|
+
}], ctorParameters: function () { return [{ type: i1.BaseHttpService }]; } });
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJpY2UtYXBpLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FwaS9zcmMvbGliL3NlcnZpY2VzL3ByaWNlLWFwaS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQUszQyxNQUFNLE9BQU8sZUFBZTtJQUcxQixZQUFvQixXQUE0QjtRQUE1QixnQkFBVyxHQUFYLFdBQVcsQ0FBaUI7UUFGL0IsZ0JBQVcsR0FBRyxRQUFRLENBQUM7SUFFVyxDQUFDO0lBRXBELGdCQUFnQixDQUFDLE9BQVk7UUFDM0IsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQztZQUMxQixNQUFNLEVBQUUsTUFBTTtZQUNkLEdBQUcsRUFBRSxHQUFHLElBQUksQ0FBQyxXQUFXLG9CQUFvQjtZQUM1QyxJQUFJLEVBQUUsT0FBTztTQUNkLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxTQUFTLENBQUMsT0FBWTtRQUNwQixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDO1lBQzFCLE1BQU0sRUFBRSxNQUFNO1lBQ2QsR0FBRyxFQUFFLEdBQUcsSUFBSSxDQUFDLFdBQVcsWUFBWTtZQUNwQyxJQUFJLEVBQUUsT0FBTztTQUNkLENBQUMsQ0FBQztRQUNILGlDQUFpQztRQUNqQyxTQUFTO1FBQ1Qsa0JBQWtCO1FBQ2xCLDBCQUEwQjtRQUMxQiwrREFBK0Q7UUFDL0QsaUNBQWlDO1FBQ2pDLHNCQUFzQjtRQUN0Qix3QkFBd0I7UUFDeEIsbUNBQW1DO1FBQ25DLHdDQUF3QztRQUN4QyxhQUFhO1FBQ2IsV0FBVztRQUVYLG9EQUFvRDtRQUNwRCxRQUFRO1FBRVIsbUJBQW1CO1FBQ25CLFFBQVE7UUFDUixLQUFLO0lBQ1AsQ0FBQztJQUVELGFBQWE7UUFDWCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDO1lBQzFCLE1BQU0sRUFBRSxLQUFLO1lBQ2IsR0FBRyxFQUFFLGNBQWM7U0FDcEIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELFlBQVksQ0FBQyxFQUFVO1FBQ3JCLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUM7WUFDMUIsTUFBTSxFQUFFLEtBQUs7WUFDYixHQUFHLEVBQUUsZ0JBQWdCLEVBQUUsRUFBRTtTQUMxQixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsdUJBQXVCLENBQ3JCLE1BQWUsRUFDZixVQUFtQixFQUNuQixTQUFnQixFQUNoQixPQUFjLEVBQ2QsYUFBc0IsRUFDdEIsaUJBQTBCO1FBRTFCLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUM7WUFDMUIsTUFBTSxFQUFFLE1BQU07WUFDZCxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsV0FBVywyQkFBMkI7WUFDbkQsSUFBSSxFQUFFO2dCQUNKLE1BQU0sRUFBRSxNQUFNO2dCQUNkLFVBQVUsRUFBRSxVQUFVO2dCQUN0QixTQUFTLEVBQUUsU0FBUztnQkFDcEIsT0FBTyxFQUFFLE9BQU87Z0JBQ2hCLGFBQWEsRUFBRSxhQUFhO2dCQUM1QixpQkFBaUIsRUFBRSxpQkFBaUI7YUFDckM7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsb0JBQW9CLENBQ2xCLE1BQWUsRUFDZixVQUFtQixFQUNuQixTQUFnQixFQUNoQixJQUFhLEVBQ2IsYUFBc0IsRUFDdEIsaUJBQTBCO1FBRTFCLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUM7WUFDMUIsTUFBTSxFQUFFLE1BQU07WUFDZCxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsV0FBVyx1QkFBdUI7WUFDL0MsSUFBSSxFQUFFO2dCQUNKLE1BQU0sRUFBRSxNQUFNO2dCQUNkLFVBQVUsRUFBRSxVQUFVO2dCQUN0QixTQUFTLEVBQUUsU0FBUztnQkFDcEIsSUFBSSxFQUFFLElBQUk7Z0JBQ1YsYUFBYSxFQUFFLGFBQWE7Z0JBQzVCLGlCQUFpQixFQUFFLGlCQUFpQjthQUNyQztTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7OzZHQWhHVSxlQUFlO2lIQUFmLGVBQWU7NEZBQWYsZUFBZTtrQkFEM0IsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJhc2VIdHRwU2VydmljZSwgUHJpY2VMaXN0LCBQcmljZVN1bW1hcnkgfSBmcm9tICdAdmVsb2NlL2NvcmUnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgUHJpY2VBcGlTZXJ2aWNlIHtcbiAgcHJpdmF0ZSByZWFkb25seSBTRVJWSUNFX1VSTCA9ICcvcHJpY2UnO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgaHR0cFNlcnZpY2U6IEJhc2VIdHRwU2VydmljZSkge31cblxuICBjYWxjdWxhdGVSdW50aW1lKHJlcXVlc3Q6IGFueSk6IE9ic2VydmFibGU8UHJpY2VTdW1tYXJ5PiB7XG4gICAgcmV0dXJuIHRoaXMuaHR0cFNlcnZpY2UuYXBpKHtcbiAgICAgIG1ldGhvZDogJ3Bvc3QnLFxuICAgICAgdXJsOiBgJHt0aGlzLlNFUlZJQ0VfVVJMfS9jYWxjdWxhdGUtcnVudGltZWAsXG4gICAgICBib2R5OiByZXF1ZXN0LFxuICAgIH0pO1xuICB9XG5cbiAgY2FsY3VsYXRlKHJlcXVlc3Q6IGFueSk6IE9ic2VydmFibGU8UHJpY2VTdW1tYXJ5PiB7XG4gICAgcmV0dXJuIHRoaXMuaHR0cFNlcnZpY2UuYXBpKHtcbiAgICAgIG1ldGhvZDogJ3Bvc3QnLFxuICAgICAgdXJsOiBgJHt0aGlzLlNFUlZJQ0VfVVJMfS9jYWxjdWxhdGVgLFxuICAgICAgYm9keTogcmVxdWVzdCxcbiAgICB9KTtcbiAgICAvLyBUT0RPOiBtb3ZlIG91dHNpZGUgQVBJIHNlcnZpY2VcbiAgICAvLyAucGlwZShcbiAgICAvLyAgIG1hcChkYXRhID0+IHtcbiAgICAvLyAgICAgaWYgKGRhdGEuY29udGV4dCkge1xuICAgIC8vICAgICAgIGNvbnN0IGNvbnRleHQgPSB0aGlzLmNvbnRleHRTZXJ2aWNlLnJlc29sdmVPckNyZWF0ZSgpO1xuICAgIC8vICAgICAgIGNvbnN0IHBhdGNoZWRDb250ZXh0ID0ge1xuICAgIC8vICAgICAgICAgLi4uY29udGV4dCxcbiAgICAvLyAgICAgICAgIHByb3BlcnRpZXM6IHtcbiAgICAvLyAgICAgICAgICAgLi4uY29udGV4dC5wcm9wZXJ0aWVzLFxuICAgIC8vICAgICAgICAgICAuLi5kYXRhLmNvbnRleHQucHJvcGVydGllcyxcbiAgICAvLyAgICAgICAgIH0sXG4gICAgLy8gICAgICAgfTtcblxuICAgIC8vICAgICAgIHRoaXMuY29udGV4dFNlcnZpY2UudXBkYXRlKHBhdGNoZWRDb250ZXh0KTtcbiAgICAvLyAgICAgfVxuXG4gICAgLy8gICAgIHJldHVybiBkYXRhO1xuICAgIC8vICAgfSksXG4gICAgLy8gKTtcbiAgfVxuXG4gIGdldFByaWNlTGlzdHMoKTogT2JzZXJ2YWJsZTxQcmljZUxpc3RbXT4ge1xuICAgIHJldHVybiB0aGlzLmh0dHBTZXJ2aWNlLmFwaSh7XG4gICAgICBtZXRob2Q6ICdnZXQnLFxuICAgICAgdXJsOiAnL3ByaWNlLWxpc3RzJyxcbiAgICB9KTtcbiAgfVxuXG4gIGdldFByaWNlTGlzdChpZDogc3RyaW5nKTogT2JzZXJ2YWJsZTxQcmljZUxpc3Q+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwU2VydmljZS5hcGkoe1xuICAgICAgbWV0aG9kOiAnZ2V0JyxcbiAgICAgIHVybDogYC9wcmljZS1saXN0cy8ke2lkfWAsXG4gICAgfSk7XG4gIH1cblxuICBnZXRTZWxsaW5nVGVybUJ5RW5kRGF0ZShcbiAgICBwbGFuSWQ/OiBzdHJpbmcsXG4gICAgb2ZmZXJpbmdJZD86IHN0cmluZyxcbiAgICBzdGFydERhdGU/OiBEYXRlLFxuICAgIGVuZERhdGU/OiBEYXRlLFxuICAgIGZyZXF1ZW5jeVVuaXQ/OiBzdHJpbmcsXG4gICAgZnJlcXVlbmN5RHVyYXRpb24/OiBzdHJpbmcsXG4gICk6IE9ic2VydmFibGU8YW55PiB7XG4gICAgcmV0dXJuIHRoaXMuaHR0cFNlcnZpY2UuYXBpKHtcbiAgICAgIG1ldGhvZDogJ3Bvc3QnLFxuICAgICAgdXJsOiBgJHt0aGlzLlNFUlZJQ0VfVVJMfS9zZWxsaW5nLXRlcm0tYnktZW5kLWRhdGVgLFxuICAgICAgYm9keToge1xuICAgICAgICBwbGFuSWQ6IHBsYW5JZCxcbiAgICAgICAgb2ZmZXJpbmdJZDogb2ZmZXJpbmdJZCxcbiAgICAgICAgc3RhcnREYXRlOiBzdGFydERhdGUsXG4gICAgICAgIGVuZERhdGU6IGVuZERhdGUsXG4gICAgICAgIGZyZXF1ZW5jeVVuaXQ6IGZyZXF1ZW5jeVVuaXQsXG4gICAgICAgIGZyZXF1ZW5jeUR1cmF0aW9uOiBmcmVxdWVuY3lEdXJhdGlvbixcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cblxuICBnZXRTZWxsaW5nVGVybUJ5VGVybShcbiAgICBwbGFuSWQ/OiBzdHJpbmcsXG4gICAgb2ZmZXJpbmdJZD86IHN0cmluZyxcbiAgICBzdGFydERhdGU/OiBEYXRlLFxuICAgIHRlcm0/OiBudW1iZXIsXG4gICAgZnJlcXVlbmN5VW5pdD86IHN0cmluZyxcbiAgICBmcmVxdWVuY3lEdXJhdGlvbj86IHN0cmluZyxcbiAgKTogT2JzZXJ2YWJsZTxhbnk+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwU2VydmljZS5hcGkoe1xuICAgICAgbWV0aG9kOiAncG9zdCcsXG4gICAgICB1cmw6IGAke3RoaXMuU0VSVklDRV9VUkx9L3NlbGxpbmctdGVybS1ieS10ZXJtYCxcbiAgICAgIGJvZHk6IHtcbiAgICAgICAgcGxhbklkOiBwbGFuSWQsXG4gICAgICAgIG9mZmVyaW5nSWQ6IG9mZmVyaW5nSWQsXG4gICAgICAgIHN0YXJ0RGF0ZTogc3RhcnREYXRlLFxuICAgICAgICB0ZXJtOiB0ZXJtLFxuICAgICAgICBmcmVxdWVuY3lVbml0OiBmcmVxdWVuY3lVbml0LFxuICAgICAgICBmcmVxdWVuY3lEdXJhdGlvbjogZnJlcXVlbmN5RHVyYXRpb24sXG4gICAgICB9LFxuICAgIH0pO1xuICB9XG59XG4iXX0=
|