@qbs-origin/origin-form 0.8.6 → 0.8.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/formly/formly-scan-id/formly-scan-id.component.mjs +326 -122
- package/esm2022/lib/formly/formly-sign/formly-sign.component.mjs +76 -47
- package/esm2022/lib/formly/formly-view-documents/formly-view-documents.component.mjs +11 -7
- package/esm2022/lib/origin-form.component.mjs +15 -1
- package/fesm2022/qbs-origin-origin-form.mjs +442 -198
- package/fesm2022/qbs-origin-origin-form.mjs.map +1 -1
- package/lib/formly/formly-scan-id/formly-scan-id.component.d.ts +44 -10
- package/lib/formly/formly-sign/formly-sign.component.d.ts +4 -0
- package/lib/formly/formly-view-documents/formly-view-documents.component.d.ts +1 -0
- package/package.json +2 -2
|
@@ -5,68 +5,95 @@ import { BaseFormlyStepComponent } from '../baseFormlyStepComponent';
|
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "../../origin-form-auth.service";
|
|
7
7
|
import * as i2 from "../../services/dialog.service";
|
|
8
|
-
import * as i3 from "@
|
|
8
|
+
import * as i3 from "@angular/common";
|
|
9
|
+
import * as i4 from "@qbs-origin/sign-lib";
|
|
10
|
+
import * as i5 from "@angular/material/button";
|
|
11
|
+
import * as i6 from "@angular/material/icon";
|
|
12
|
+
import * as i7 from "@angular/material/progress-bar";
|
|
9
13
|
export class FormlySignComponent extends BaseFormlyStepComponent {
|
|
10
14
|
constructor(authService, cdr, dialog) {
|
|
11
15
|
super(cdr);
|
|
12
16
|
this.authService = authService;
|
|
13
17
|
this.dialog = dialog;
|
|
14
18
|
this.canProceed = false;
|
|
19
|
+
this.isInitializing = true;
|
|
20
|
+
this.initError = null;
|
|
21
|
+
this.isSignComplete = false;
|
|
15
22
|
this._signButtonStyle = {};
|
|
16
23
|
this.configService = inject(ConfigService);
|
|
17
24
|
}
|
|
18
25
|
onInit() { }
|
|
19
26
|
async onPageSelectedAsync() {
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
Object.keys(styleObj).forEach((key) => {
|
|
24
|
-
const camelKey = key.replace(/-([a-z])/g, (g) => g[1].toUpperCase());
|
|
25
|
-
camelCaseStyle[camelKey] = styleObj[key];
|
|
26
|
-
});
|
|
27
|
-
this._signButtonStyle = camelCaseStyle;
|
|
28
|
-
}
|
|
29
|
-
else {
|
|
30
|
-
this._signButtonStyle = {};
|
|
31
|
-
}
|
|
32
|
-
// Reset component state when page is selected
|
|
33
|
-
this.canProceed = false;
|
|
34
|
-
this.config = await this.getConfig();
|
|
35
|
-
this.addPhoneNumbertoConfig();
|
|
36
|
-
this.config = {
|
|
37
|
-
...this.config,
|
|
38
|
-
ShowConfirm: this.stepData.config.showConfirm ?? false,
|
|
39
|
-
SignMode: this.stepData.config.companySign ?? false ? 'both' : 'client',
|
|
40
|
-
...(Object.keys(this.signButtonStyle).length > 0
|
|
41
|
-
? {
|
|
42
|
-
Styles: {
|
|
43
|
-
...(this.config.Styles || {}),
|
|
44
|
-
buttonStyles: this.signButtonStyle,
|
|
45
|
-
},
|
|
46
|
-
}
|
|
47
|
-
: {}),
|
|
48
|
-
};
|
|
49
|
-
if (this.config.Styles?.buttonStyles) {
|
|
50
|
-
console.log(`🧫 FormlySignComponent: Styles for sign button are sent:`, this.config.Styles.buttonStyles);
|
|
51
|
-
console.log('config', this.config);
|
|
52
|
-
}
|
|
53
|
-
console.log(`🔷 FormlySignComponent: Initializing sign component for step ${this.stepData.identifier}`);
|
|
54
|
-
//very important to trigger input parameter pass to SignLib component
|
|
27
|
+
this.isInitializing = true;
|
|
28
|
+
this.initError = null;
|
|
29
|
+
this.isSignComplete = false;
|
|
55
30
|
this.cdr.detectChanges();
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
31
|
+
try {
|
|
32
|
+
const styleObj = this.props?.['design']?.['.button-otpaction'];
|
|
33
|
+
if (styleObj) {
|
|
34
|
+
const camelCaseStyle = {};
|
|
35
|
+
Object.keys(styleObj).forEach((key) => {
|
|
36
|
+
const camelKey = key.replace(/-([a-z])/g, (g) => g[1].toUpperCase());
|
|
37
|
+
camelCaseStyle[camelKey] = styleObj[key];
|
|
38
|
+
});
|
|
39
|
+
this._signButtonStyle = camelCaseStyle;
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
this._signButtonStyle = {};
|
|
43
|
+
}
|
|
44
|
+
// Reset component state when page is selected
|
|
45
|
+
this.canProceed = false;
|
|
46
|
+
this.config = await this.getConfig();
|
|
47
|
+
this.addPhoneNumbertoConfig();
|
|
48
|
+
this.config = {
|
|
49
|
+
...this.config,
|
|
50
|
+
ShowConfirm: this.stepData.config.showConfirm ?? false,
|
|
51
|
+
SignMode: this.stepData.config.companySign ?? false ? 'both' : 'client',
|
|
52
|
+
...(Object.keys(this.signButtonStyle).length > 0
|
|
53
|
+
? {
|
|
54
|
+
Styles: {
|
|
55
|
+
...(this.config.Styles || {}),
|
|
56
|
+
buttonStyles: this.signButtonStyle,
|
|
57
|
+
},
|
|
58
|
+
}
|
|
59
|
+
: {}),
|
|
60
|
+
};
|
|
61
|
+
if (this.config.Styles?.buttonStyles) {
|
|
62
|
+
console.log(`🧫 FormlySignComponent: Styles for sign button are sent:`, this.config.Styles.buttonStyles);
|
|
63
|
+
console.log('config', this.config);
|
|
64
|
+
}
|
|
65
|
+
console.log(`🔷 FormlySignComponent: Initializing sign component for step ${this.stepData.identifier}`);
|
|
66
|
+
this.isInitializing = false;
|
|
67
|
+
//very important to trigger input parameter pass to SignLib component
|
|
68
|
+
this.cdr.detectChanges();
|
|
69
|
+
// Wait a bit for ViewChild to be available and then initialize
|
|
70
|
+
await new Promise((resolve) => setTimeout(resolve, 50));
|
|
71
|
+
// Ensure SignLibComponent is properly initialized
|
|
72
|
+
if (this.signLib) {
|
|
73
|
+
console.log(`🔷 FormlySignComponent: SignLibComponent found, calling ngOnInit for step ${this.stepData.identifier}`);
|
|
74
|
+
await this.signLib.ngOnInit();
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
console.warn(`🔷 FormlySignComponent: SignLibComponent not found for step ${this.stepData.identifier}`);
|
|
78
|
+
this.initError = 'Failed to initialize signature component';
|
|
79
|
+
this.cdr.detectChanges();
|
|
80
|
+
}
|
|
62
81
|
}
|
|
63
|
-
|
|
64
|
-
console.
|
|
82
|
+
catch (error) {
|
|
83
|
+
console.error('🔷 FormlySignComponent: Error during initialization:', error);
|
|
84
|
+
this.isInitializing = false;
|
|
85
|
+
this.initError = 'Failed to initialize signature component';
|
|
86
|
+
this.cdr.detectChanges();
|
|
65
87
|
}
|
|
66
88
|
}
|
|
67
89
|
async retryAsync() {
|
|
68
90
|
await this.onPageSelectedAsync();
|
|
69
91
|
}
|
|
92
|
+
async retryInit() {
|
|
93
|
+
this.initError = null;
|
|
94
|
+
this.isSignComplete = false;
|
|
95
|
+
await this.onPageSelectedAsync();
|
|
96
|
+
}
|
|
70
97
|
async getConfig() {
|
|
71
98
|
return {
|
|
72
99
|
AppDataId: this.props['appDataId'],
|
|
@@ -127,6 +154,8 @@ export class FormlySignComponent extends BaseFormlyStepComponent {
|
|
|
127
154
|
libEvent(event) {
|
|
128
155
|
if (event && event.toLowerCase() === 'success') {
|
|
129
156
|
this.canProceed = true;
|
|
157
|
+
this.isSignComplete = true;
|
|
158
|
+
this.cdr.detectChanges();
|
|
130
159
|
}
|
|
131
160
|
this.onEvent(event);
|
|
132
161
|
}
|
|
@@ -161,13 +190,13 @@ export class FormlySignComponent extends BaseFormlyStepComponent {
|
|
|
161
190
|
console.log('🔷 FormlySignComponent: Component cleanup completed');
|
|
162
191
|
}
|
|
163
192
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormlySignComponent, deps: [{ token: i1.OriginFormAuthService }, { token: i0.ChangeDetectorRef }, { token: i2.DialogService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
164
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: FormlySignComponent, selector: "formly-sign", viewQueries: [{ propertyName: "signLib", first: true, predicate: ["signLib"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<lib-sign #signLib
|
|
193
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: FormlySignComponent, selector: "formly-sign", viewQueries: [{ propertyName: "signLib", first: true, predicate: ["signLib"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"sign-container\">\n <!-- Loading State -->\n <div class=\"sign-loading\" *ngIf=\"isInitializing && !initError\">\n <mat-progress-bar mode=\"indeterminate\"></mat-progress-bar>\n </div>\n\n <!-- Error State -->\n <div class=\"sign-error\" *ngIf=\"initError\" role=\"alert\" aria-live=\"assertive\">\n <mat-icon>error_outline</mat-icon>\n <span>{{ initError }}</span>\n <button mat-stroked-button (click)=\"retryInit()\">\n <mat-icon>refresh</mat-icon>\n Retry\n </button>\n </div>\n\n <!-- Sign Library -->\n <lib-sign #signLib\n [config]=\"config\"\n (event)=\"libEvent($event)\"\n [hidden]=\"isInitializing || initError\">\n </lib-sign>\n\n <!-- Success State -->\n <div class=\"sign-success\" *ngIf=\"isSignComplete\" role=\"status\" aria-live=\"polite\">\n <mat-icon class=\"sign-success__icon\">check_circle</mat-icon>\n </div>\n</div>\n", styles: [":host{display:block}.sign-loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 16px}.sign-loading mat-progress-bar{width:100%;max-width:400px;border-radius:7px}.sign-error{display:flex;align-items:center;gap:12px;padding:12px 16px;margin:16px auto;max-width:600px;background:#fa896b14;border:1px solid #fa896b;border-radius:7px;color:#2a3547;text-align:left}.sign-error>mat-icon{color:#fa896b;flex-shrink:0}.sign-error>span{flex:1;font-size:14px}.sign-error button{display:flex;align-items:center;gap:6px;min-height:36px;border-radius:7px;flex-shrink:0}@media (max-width: 600px){.sign-error{flex-wrap:wrap}.sign-error button{width:100%;justify-content:center}}.sign-success{display:flex;flex-direction:column;align-items:center;gap:12px;padding:32px 16px;margin:16px auto;max-width:600px;background:#13deb914;border:1px solid #13deb9;border-radius:7px}.sign-success__icon{font-size:48px;width:48px;height:48px;color:#13deb9}:host-context(.dark-theme) .sign-error{background:#fa896b1a;color:#ffffffde}:host-context(.dark-theme) .sign-success{background:#13deb91a}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.SignLibComponent, selector: "lib-sign", inputs: ["config", "instanceId"], outputs: ["event"] }, { kind: "component", type: i5.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i7.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }] }); }
|
|
165
194
|
}
|
|
166
195
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormlySignComponent, decorators: [{
|
|
167
196
|
type: Component,
|
|
168
|
-
args: [{ selector: 'formly-sign', template: "<lib-sign #signLib
|
|
197
|
+
args: [{ selector: 'formly-sign', template: "<div class=\"sign-container\">\n <!-- Loading State -->\n <div class=\"sign-loading\" *ngIf=\"isInitializing && !initError\">\n <mat-progress-bar mode=\"indeterminate\"></mat-progress-bar>\n </div>\n\n <!-- Error State -->\n <div class=\"sign-error\" *ngIf=\"initError\" role=\"alert\" aria-live=\"assertive\">\n <mat-icon>error_outline</mat-icon>\n <span>{{ initError }}</span>\n <button mat-stroked-button (click)=\"retryInit()\">\n <mat-icon>refresh</mat-icon>\n Retry\n </button>\n </div>\n\n <!-- Sign Library -->\n <lib-sign #signLib\n [config]=\"config\"\n (event)=\"libEvent($event)\"\n [hidden]=\"isInitializing || initError\">\n </lib-sign>\n\n <!-- Success State -->\n <div class=\"sign-success\" *ngIf=\"isSignComplete\" role=\"status\" aria-live=\"polite\">\n <mat-icon class=\"sign-success__icon\">check_circle</mat-icon>\n </div>\n</div>\n", styles: [":host{display:block}.sign-loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 16px}.sign-loading mat-progress-bar{width:100%;max-width:400px;border-radius:7px}.sign-error{display:flex;align-items:center;gap:12px;padding:12px 16px;margin:16px auto;max-width:600px;background:#fa896b14;border:1px solid #fa896b;border-radius:7px;color:#2a3547;text-align:left}.sign-error>mat-icon{color:#fa896b;flex-shrink:0}.sign-error>span{flex:1;font-size:14px}.sign-error button{display:flex;align-items:center;gap:6px;min-height:36px;border-radius:7px;flex-shrink:0}@media (max-width: 600px){.sign-error{flex-wrap:wrap}.sign-error button{width:100%;justify-content:center}}.sign-success{display:flex;flex-direction:column;align-items:center;gap:12px;padding:32px 16px;margin:16px auto;max-width:600px;background:#13deb914;border:1px solid #13deb9;border-radius:7px}.sign-success__icon{font-size:48px;width:48px;height:48px;color:#13deb9}:host-context(.dark-theme) .sign-error{background:#fa896b1a;color:#ffffffde}:host-context(.dark-theme) .sign-success{background:#13deb91a}\n"] }]
|
|
169
198
|
}], ctorParameters: () => [{ type: i1.OriginFormAuthService }, { type: i0.ChangeDetectorRef }, { type: i2.DialogService }], propDecorators: { signLib: [{
|
|
170
199
|
type: ViewChild,
|
|
171
200
|
args: ['signLib']
|
|
172
201
|
}] } });
|
|
173
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-sign.component.js","sourceRoot":"","sources":["../../../../../../projects/origin-form/src/lib/formly/formly-sign/formly-sign.component.ts","../../../../../../projects/origin-form/src/lib/formly/formly-sign/formly-sign.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,SAAS,EACT,MAAM,GAGP,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAG5D,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AACpD,OAAO,EAAE,uBAAuB,EAAE,MAAM,4BAA4B,CAAC;;;;;AAOrE,MAAM,OAAO,mBACX,SAAQ,uBAAuB;IAQ/B,YACS,WAAkC,EACzC,GAAsB,EACd,MAAqB;QAE7B,KAAK,CAAC,GAAG,CAAC,CAAC;QAJJ,gBAAW,GAAX,WAAW,CAAuB;QAEjC,WAAM,GAAN,MAAM,CAAe;QAP/B,eAAU,GAAY,KAAK,CAAC;QACpB,qBAAgB,GAA8B,EAAE,CAAC;QAEzD,kBAAa,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;IAOtC,CAAC;IAEQ,MAAM,KAAI,CAAC;IAEX,KAAK,CAAC,mBAAmB;QAChC,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,mBAAmB,CAAC,CAAC;QAC/D,IAAI,QAAQ,EAAE,CAAC;YACb,MAAM,cAAc,GAA8B,EAAE,CAAC;YACrD,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;gBACpC,MAAM,QAAQ,GAAG,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;gBACrE,cAAc,CAAC,QAAQ,CAAC,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC;YAC3C,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,gBAAgB,GAAG,cAAc,CAAC;QACzC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;QAC7B,CAAC;QACD,8CAA8C;QAC9C,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QAExB,IAAI,CAAC,MAAM,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC;QACrC,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAE9B,IAAI,CAAC,MAAM,GAAG;YACZ,GAAG,IAAI,CAAC,MAAM;YACd,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,WAAW,IAAI,KAAK;YACtD,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,WAAW,IAAI,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ;YACvE,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,MAAM,GAAG,CAAC;gBAC9C,CAAC,CAAC;oBACE,MAAM,EAAE;wBACN,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,EAAE,CAAC;wBAC7B,YAAY,EAAE,IAAI,CAAC,eAAe;qBACnC;iBACF;gBACH,CAAC,CAAC,EAAE,CAAC;SACR,CAAC;QAEF,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,YAAY,EAAE,CAAC;YACrC,OAAO,CAAC,GAAG,CACT,0DAA0D,EAC1D,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,YAAY,CAChC,CAAC;YACF,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QACrC,CAAC;QAED,OAAO,CAAC,GAAG,CACT,gEAAgE,IAAI,CAAC,QAAQ,CAAC,UAAU,EAAE,CAC3F,CAAC;QAEF,qEAAqE;QACrE,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAEzB,+DAA+D;QAC/D,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;QAExD,kDAAkD;QAClD,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,OAAO,CAAC,GAAG,CACT,6EAA6E,IAAI,CAAC,QAAQ,CAAC,UAAU,EAAE,CACxG,CAAC;YACF,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;QAChC,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,IAAI,CACV,+DAA+D,IAAI,CAAC,QAAQ,CAAC,UAAU,EAAE,CAC1F,CAAC;QACJ,CAAC;IACH,CAAC;IAED,KAAK,CAAC,UAAU;QACd,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAC;IACnC,CAAC;IAED,KAAK,CAAC,SAAS;QACb,OAAO;YACL,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC;YAClC,MAAM,EAAE,IAAI,CAAC,QAAQ,CAAC,UAAU;YAChC,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE;YAClC,OAAO,EAAE,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,CAAC,cAAc;YACvD,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,SAAS,KAAK,KAAK;SAC5C,CAAC;IACJ,CAAC;IAEO,sBAAsB;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,kBAAkB,CAAC;QAEzD,IAAI,QAAQ,EAAE,CAAC;YACb,IAAI,WAAW,GAAG,IAAI,CAAC;YAEvB,qDAAqD;YACrD,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;YAC5C,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE,CAAC;YACvC,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAEhC,0EAA0E;YAC1E,MAAM,WAAW,GAAG,UAAU,EAAE,GAAG,CAAC,QAAQ,CAAC,CAAC;YAC9C,WAAW,GAAG,WAAW,EAAE,KAAK,CAAC;YAEjC,+CAA+C;YAC/C,IAAI,CAAC,WAAW,IAAI,KAAK,IAAI,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC7C,WAAW,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC;YAChC,CAAC;YAED,IAAI,CAAC,WAAW,IAAI,QAAQ,KAAK,iBAAiB,IAAI,IAAI,EAAE,CAAC;gBAC3D,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CACzB,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC,KAAK,CAC5C,CAAC;gBACF,IACE,SAAS;oBACT,SAAS,CAAC,MAAM;oBAChB,SAAS,CAAC,MAAM,CAAC,kBAAkB,EACnC,CAAC;oBACD,MAAM,gBAAgB,GAAG,SAAS,CAAC,MAAM,CAAC,kBAAkB,CAAC;oBAC7D,yCAAyC;oBACzC,WAAW;wBACT,UAAU,EAAE,GAAG,CAAC,gBAAgB,CAAC,EAAE,KAAK;4BACxC,CAAC,KAAK,IAAI,KAAK,CAAC,gBAAgB,CAAC,CAAC,CAAC;gBACvC,CAAC;YACH,CAAC;YAED,IAAI,WAAW,EAAE,CAAC;gBAChB,IAAI,CAAC,MAAM,GAAG;oBACZ,GAAG,IAAI,CAAC,MAAM;oBACd,WAAW,EAAE,WAAW;iBACzB,CAAC;YACJ,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,IAAI,CACV,wDAAwD,EACxD,QAAQ,CACT,CAAC;YACJ,CAAC;QACH,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,IAAI,CACV,wEAAwE,CACzE,CAAC;QACJ,CAAC;IACH,CAAC;IAEQ,UAAU;QACjB,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;YACrB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,qCAAqC,CAAC,CAAC;YAC5D,OAAO,KAAK,CAAC;QACf,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,QAAQ,CAAC,KAAU;QACjB,IAAI,KAAK,IAAI,KAAK,CAAC,WAAW,EAAE,KAAK,SAAS,EAAE,CAAC;YAC/C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACzB,CAAC;QACD,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IACtB,CAAC;IAED,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;IAED,WAAW;QACT,OAAO,CAAC,GAAG,CACT,+EAA+E,CAChF,CAAC;QAEF,wCAAwC;QACxC,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,CAAC;gBACH,gFAAgF;gBAChF,IAAI,OAAQ,IAAI,CAAC,OAAe,CAAC,WAAW,KAAK,UAAU,EAAE,CAAC;oBAC3D,IAAI,CAAC,OAAe,CAAC,WAAW,EAAE,CAAC;gBACtC,CAAC;qBAAM,IAAI,OAAQ,IAAI,CAAC,OAAe,CAAC,OAAO,KAAK,UAAU,EAAE,CAAC;oBAC9D,IAAI,CAAC,OAAe,CAAC,OAAO,EAAE,CAAC;gBAClC,CAAC;qBAAM,IAAI,OAAQ,IAAI,CAAC,OAAe,CAAC,OAAO,KAAK,UAAU,EAAE,CAAC;oBAC9D,IAAI,CAAC,OAAe,CAAC,OAAO,EAAE,CAAC;gBAClC,CAAC;gBAED,uBAAuB;gBACtB,IAAI,CAAC,OAAe,GAAG,IAAI,CAAC;YAC/B,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,OAAO,CAAC,IAAI,CACV,gEAAgE,EAChE,KAAK,CACN,CAAC;YACJ,CAAC;QACH,CAAC;QAED,wBAAwB;QACxB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QAEnB,OAAO,CAAC,GAAG,CAAC,qDAAqD,CAAC,CAAC;IACrE,CAAC;+GA1MU,mBAAmB;mGAAnB,mBAAmB,8KCpBhC,oFACA;;4FDmBa,mBAAmB;kBAL/B,SAAS;+BACE,aAAa;sJAQD,OAAO;sBAA5B,SAAS;uBAAC,SAAS","sourcesContent":["import {\n  Component,\n  ViewChild,\n  inject,\n  ChangeDetectorRef,\n  OnDestroy,\n} from '@angular/core';\nimport { SignLibComponent } from '@qbs-origin/sign-lib';\nimport { firstValueFrom } from 'rxjs';\nimport { ConfigService } from '../../others/config-service';\nimport { OriginFormAuthService } from '../../origin-form-auth.service';\nimport { DialogService } from '../../services/dialog.service';\nimport { FluxType } from '../../models/forms.model';\nimport { BaseFormlyStepComponent } from '../baseFormlyStepComponent';\n\n@Component({\n  selector: 'formly-sign',\n  templateUrl: './formly-sign.component.html',\n  styleUrl: './formly-sign.component.scss',\n})\nexport class FormlySignComponent\n  extends BaseFormlyStepComponent\n  implements OnDestroy\n{\n  @ViewChild('signLib') signLib: SignLibComponent;\n  canProceed: boolean = false;\n  private _signButtonStyle: { [key: string]: string } = {};\n  public config: any;\n  configService = inject(ConfigService);\n  constructor(\n    public authService: OriginFormAuthService,\n    cdr: ChangeDetectorRef,\n    private dialog: DialogService\n  ) {\n    super(cdr);\n  }\n\n  override onInit() {}\n\n  override async onPageSelectedAsync() {\n    const styleObj = this.props?.['design']?.['.button-otpaction'];\n    if (styleObj) {\n      const camelCaseStyle: { [key: string]: string } = {};\n      Object.keys(styleObj).forEach((key) => {\n        const camelKey = key.replace(/-([a-z])/g, (g) => g[1].toUpperCase());\n        camelCaseStyle[camelKey] = styleObj[key];\n      });\n      this._signButtonStyle = camelCaseStyle;\n    } else {\n      this._signButtonStyle = {};\n    }\n    // Reset component state when page is selected\n    this.canProceed = false;\n\n    this.config = await this.getConfig();\n    this.addPhoneNumbertoConfig();\n\n    this.config = {\n      ...this.config,\n      ShowConfirm: this.stepData.config.showConfirm ?? false,\n      SignMode: this.stepData.config.companySign ?? false ? 'both' : 'client',\n      ...(Object.keys(this.signButtonStyle).length > 0\n        ? {\n            Styles: {\n              ...(this.config.Styles || {}),\n              buttonStyles: this.signButtonStyle,\n            },\n          }\n        : {}),\n    };\n\n    if (this.config.Styles?.buttonStyles) {\n      console.log(\n        `🧫 FormlySignComponent: Styles for sign button are sent:`,\n        this.config.Styles.buttonStyles\n      );\n      console.log('config', this.config);\n    }\n\n    console.log(\n      `🔷 FormlySignComponent: Initializing sign component for step ${this.stepData.identifier}`\n    );\n\n    //very important to trigger input parameter pass to SignLib component\n    this.cdr.detectChanges();\n\n    // Wait a bit for ViewChild to be available and then initialize\n    await new Promise((resolve) => setTimeout(resolve, 50));\n\n    // Ensure SignLibComponent is properly initialized\n    if (this.signLib) {\n      console.log(\n        `🔷 FormlySignComponent: SignLibComponent found, calling ngOnInit for step ${this.stepData.identifier}`\n      );\n      await this.signLib.ngOnInit();\n    } else {\n      console.warn(\n        `🔷 FormlySignComponent: SignLibComponent not found for step ${this.stepData.identifier}`\n      );\n    }\n  }\n\n  async retryAsync() {\n    await this.onPageSelectedAsync();\n  }\n\n  async getConfig() {\n    return {\n      AppDataId: this.props['appDataId'],\n      StepId: this.stepData.identifier,\n      Token: this.authService.getToken(),\n      BaseUrl: this.configService.readConfig().baseUrlGateway,\n      AutoSign: this.stepData.isVisible === false,\n    };\n  }\n\n  private addPhoneNumbertoConfig(): void {\n    const phoneKey = this.stepData.config.componentCollected;\n\n    if (phoneKey) {\n      let phoneNumber = null;\n\n      // Get references to parent form and model from props\n      const parentForm = this.props['parentForm'];\n      const model = this.props['getModel']();\n      const flux = this.props['flux'];\n\n      // First try to get from parent form control (for validated phone numbers)\n      const formControl = parentForm?.get(phoneKey);\n      phoneNumber = formControl?.value;\n\n      // If not found in form control, try from model\n      if (!phoneNumber && model && model[phoneKey]) {\n        phoneNumber = model[phoneKey];\n      }\n\n      if (!phoneNumber && phoneKey === 'validated-phone' && flux) {\n        const phoneStep = flux.find(\n          (step: any) => step.type === FluxType.Phone\n        );\n        if (\n          phoneStep &&\n          phoneStep.config &&\n          phoneStep.config.componentCollected\n        ) {\n          const originalPhoneKey = phoneStep.config.componentCollected;\n          // Try from parent form first, then model\n          phoneNumber =\n            parentForm?.get(originalPhoneKey)?.value ||\n            (model && model[originalPhoneKey]);\n        }\n      }\n\n      if (phoneNumber) {\n        this.config = {\n          ...this.config,\n          PhoneNumber: phoneNumber,\n        };\n      } else {\n        console.warn(\n          '🔷 FormlySignComponent: No phone number found for key:',\n          phoneKey\n        );\n      }\n    } else {\n      console.warn(\n        '🔷 FormlySignComponent: No componentCollected key found in step config'\n      );\n    }\n  }\n\n  override canAdvance(): boolean {\n    if (!this.canProceed) {\n      this.dialog.popError('signComponent.viewfiles.waitForSign');\n      return false;\n    }\n    return true;\n  }\n\n  libEvent(event: any) {\n    if (event && event.toLowerCase() === 'success') {\n      this.canProceed = true;\n    }\n    this.onEvent(event);\n  }\n\n  get signButtonStyle(): { [key: string]: string } {\n    return this._signButtonStyle;\n  }\n\n  ngOnDestroy(): void {\n    console.log(\n      '🔷 FormlySignComponent: Destroying component and cleaning up SignLibComponent'\n    );\n\n    // Cleanup SignLibComponent if it exists\n    if (this.signLib) {\n      try {\n        // Call destroy method if it exists (check for various possible cleanup methods)\n        if (typeof (this.signLib as any).ngOnDestroy === 'function') {\n          (this.signLib as any).ngOnDestroy();\n        } else if (typeof (this.signLib as any).destroy === 'function') {\n          (this.signLib as any).destroy();\n        } else if (typeof (this.signLib as any).cleanup === 'function') {\n          (this.signLib as any).cleanup();\n        }\n\n        // Clear any references\n        (this.signLib as any) = null;\n      } catch (error) {\n        console.warn(\n          '🔷 FormlySignComponent: Error during SignLibComponent cleanup:',\n          error\n        );\n      }\n    }\n\n    // Reset component state\n    this.canProceed = false;\n    this.config = null;\n\n    console.log('🔷 FormlySignComponent: Component cleanup completed');\n  }\n}\n","<lib-sign #signLib [config]=\"config\" (event)=\"libEvent($event)\"> </lib-sign>\n"]}
|
|
202
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-sign.component.js","sourceRoot":"","sources":["../../../../../../projects/origin-form/src/lib/formly/formly-sign/formly-sign.component.ts","../../../../../../projects/origin-form/src/lib/formly/formly-sign/formly-sign.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ViewChild,\n  inject,\n  ChangeDetectorRef,\n  OnDestroy,\n} from '@angular/core';\nimport { SignLibComponent } from '@qbs-origin/sign-lib';\nimport { firstValueFrom } from 'rxjs';\nimport { ConfigService } from '../../others/config-service';\nimport { OriginFormAuthService } from '../../origin-form-auth.service';\nimport { DialogService } from '../../services/dialog.service';\nimport { FluxType } from '../../models/forms.model';\nimport { BaseFormlyStepComponent } from '../baseFormlyStepComponent';\n\n@Component({\n  selector: 'formly-sign',\n  templateUrl: './formly-sign.component.html',\n  styleUrl: './formly-sign.component.scss',\n})\nexport class FormlySignComponent\n  extends BaseFormlyStepComponent\n  implements OnDestroy\n{\n  @ViewChild('signLib') signLib: SignLibComponent;\n  canProceed: boolean = false;\n  isInitializing: boolean = true;\n  initError: string | null = null;\n  isSignComplete: boolean = false;\n  private _signButtonStyle: { [key: string]: string } = {};\n  public config: any;\n  configService = inject(ConfigService);\n  constructor(\n    public authService: OriginFormAuthService,\n    cdr: ChangeDetectorRef,\n    private dialog: DialogService\n  ) {\n    super(cdr);\n  }\n\n  override onInit() {}\n\n  override async onPageSelectedAsync() {\n    this.isInitializing = true;\n    this.initError = null;\n    this.isSignComplete = false;\n    this.cdr.detectChanges();\n\n    try {\n      const styleObj = this.props?.['design']?.['.button-otpaction'];\n      if (styleObj) {\n        const camelCaseStyle: { [key: string]: string } = {};\n        Object.keys(styleObj).forEach((key) => {\n          const camelKey = key.replace(/-([a-z])/g, (g) =>\n            g[1].toUpperCase()\n          );\n          camelCaseStyle[camelKey] = styleObj[key];\n        });\n        this._signButtonStyle = camelCaseStyle;\n      } else {\n        this._signButtonStyle = {};\n      }\n      // Reset component state when page is selected\n      this.canProceed = false;\n\n      this.config = await this.getConfig();\n      this.addPhoneNumbertoConfig();\n\n      this.config = {\n        ...this.config,\n        ShowConfirm: this.stepData.config.showConfirm ?? false,\n        SignMode:\n          this.stepData.config.companySign ?? false ? 'both' : 'client',\n        ...(Object.keys(this.signButtonStyle).length > 0\n          ? {\n              Styles: {\n                ...(this.config.Styles || {}),\n                buttonStyles: this.signButtonStyle,\n              },\n            }\n          : {}),\n      };\n\n      if (this.config.Styles?.buttonStyles) {\n        console.log(\n          `🧫 FormlySignComponent: Styles for sign button are sent:`,\n          this.config.Styles.buttonStyles\n        );\n        console.log('config', this.config);\n      }\n\n      console.log(\n        `🔷 FormlySignComponent: Initializing sign component for step ${this.stepData.identifier}`\n      );\n\n      this.isInitializing = false;\n      //very important to trigger input parameter pass to SignLib component\n      this.cdr.detectChanges();\n\n      // Wait a bit for ViewChild to be available and then initialize\n      await new Promise((resolve) => setTimeout(resolve, 50));\n\n      // Ensure SignLibComponent is properly initialized\n      if (this.signLib) {\n        console.log(\n          `🔷 FormlySignComponent: SignLibComponent found, calling ngOnInit for step ${this.stepData.identifier}`\n        );\n        await this.signLib.ngOnInit();\n      } else {\n        console.warn(\n          `🔷 FormlySignComponent: SignLibComponent not found for step ${this.stepData.identifier}`\n        );\n        this.initError = 'Failed to initialize signature component';\n        this.cdr.detectChanges();\n      }\n    } catch (error) {\n      console.error(\n        '🔷 FormlySignComponent: Error during initialization:',\n        error\n      );\n      this.isInitializing = false;\n      this.initError = 'Failed to initialize signature component';\n      this.cdr.detectChanges();\n    }\n  }\n\n  async retryAsync() {\n    await this.onPageSelectedAsync();\n  }\n\n  async retryInit() {\n    this.initError = null;\n    this.isSignComplete = false;\n    await this.onPageSelectedAsync();\n  }\n\n  async getConfig() {\n    return {\n      AppDataId: this.props['appDataId'],\n      StepId: this.stepData.identifier,\n      Token: this.authService.getToken(),\n      BaseUrl: this.configService.readConfig().baseUrlGateway,\n      AutoSign: this.stepData.isVisible === false,\n    };\n  }\n\n  private addPhoneNumbertoConfig(): void {\n    const phoneKey = this.stepData.config.componentCollected;\n\n    if (phoneKey) {\n      let phoneNumber = null;\n\n      // Get references to parent form and model from props\n      const parentForm = this.props['parentForm'];\n      const model = this.props['getModel']();\n      const flux = this.props['flux'];\n\n      // First try to get from parent form control (for validated phone numbers)\n      const formControl = parentForm?.get(phoneKey);\n      phoneNumber = formControl?.value;\n\n      // If not found in form control, try from model\n      if (!phoneNumber && model && model[phoneKey]) {\n        phoneNumber = model[phoneKey];\n      }\n\n      if (!phoneNumber && phoneKey === 'validated-phone' && flux) {\n        const phoneStep = flux.find(\n          (step: any) => step.type === FluxType.Phone\n        );\n        if (\n          phoneStep &&\n          phoneStep.config &&\n          phoneStep.config.componentCollected\n        ) {\n          const originalPhoneKey = phoneStep.config.componentCollected;\n          // Try from parent form first, then model\n          phoneNumber =\n            parentForm?.get(originalPhoneKey)?.value ||\n            (model && model[originalPhoneKey]);\n        }\n      }\n\n      if (phoneNumber) {\n        this.config = {\n          ...this.config,\n          PhoneNumber: phoneNumber,\n        };\n      } else {\n        console.warn(\n          '🔷 FormlySignComponent: No phone number found for key:',\n          phoneKey\n        );\n      }\n    } else {\n      console.warn(\n        '🔷 FormlySignComponent: No componentCollected key found in step config'\n      );\n    }\n  }\n\n  override canAdvance(): boolean {\n    if (!this.canProceed) {\n      this.dialog.popError('signComponent.viewfiles.waitForSign');\n      return false;\n    }\n    return true;\n  }\n\n  libEvent(event: any) {\n    if (event && event.toLowerCase() === 'success') {\n      this.canProceed = true;\n      this.isSignComplete = true;\n      this.cdr.detectChanges();\n    }\n    this.onEvent(event);\n  }\n\n  get signButtonStyle(): { [key: string]: string } {\n    return this._signButtonStyle;\n  }\n\n  ngOnDestroy(): void {\n    console.log(\n      '🔷 FormlySignComponent: Destroying component and cleaning up SignLibComponent'\n    );\n\n    // Cleanup SignLibComponent if it exists\n    if (this.signLib) {\n      try {\n        // Call destroy method if it exists (check for various possible cleanup methods)\n        if (typeof (this.signLib as any).ngOnDestroy === 'function') {\n          (this.signLib as any).ngOnDestroy();\n        } else if (typeof (this.signLib as any).destroy === 'function') {\n          (this.signLib as any).destroy();\n        } else if (typeof (this.signLib as any).cleanup === 'function') {\n          (this.signLib as any).cleanup();\n        }\n\n        // Clear any references\n        (this.signLib as any) = null;\n      } catch (error) {\n        console.warn(\n          '🔷 FormlySignComponent: Error during SignLibComponent cleanup:',\n          error\n        );\n      }\n    }\n\n    // Reset component state\n    this.canProceed = false;\n    this.config = null;\n\n    console.log('🔷 FormlySignComponent: Component cleanup completed');\n  }\n}\n","<div class=\"sign-container\">\n  <!-- Loading State -->\n  <div class=\"sign-loading\" *ngIf=\"isInitializing && !initError\">\n    <mat-progress-bar mode=\"indeterminate\"></mat-progress-bar>\n  </div>\n\n  <!-- Error State -->\n  <div class=\"sign-error\" *ngIf=\"initError\" role=\"alert\" aria-live=\"assertive\">\n    <mat-icon>error_outline</mat-icon>\n    <span>{{ initError }}</span>\n    <button mat-stroked-button (click)=\"retryInit()\">\n      <mat-icon>refresh</mat-icon>\n      Retry\n    </button>\n  </div>\n\n  <!-- Sign Library -->\n  <lib-sign #signLib\n            [config]=\"config\"\n            (event)=\"libEvent($event)\"\n            [hidden]=\"isInitializing || initError\">\n  </lib-sign>\n\n  <!-- Success State -->\n  <div class=\"sign-success\" *ngIf=\"isSignComplete\" role=\"status\" aria-live=\"polite\">\n    <mat-icon class=\"sign-success__icon\">check_circle</mat-icon>\n  </div>\n</div>\n"]}
|
|
@@ -7,7 +7,9 @@ import * as i1 from "../../services/applicationData.service";
|
|
|
7
7
|
import * as i2 from "../../services/dialog.service";
|
|
8
8
|
import * as i3 from "@angular/common";
|
|
9
9
|
import * as i4 from "ng2-pdf-viewer";
|
|
10
|
-
import * as i5 from "@angular/material/
|
|
10
|
+
import * as i5 from "@angular/material/button";
|
|
11
|
+
import * as i6 from "@angular/material/icon";
|
|
12
|
+
import * as i7 from "@angular/material/progress-bar";
|
|
11
13
|
export class FormlyViewDocumentsComponent extends BaseFormlyControlComponent {
|
|
12
14
|
constructor(appDataService, dialog, cdr) {
|
|
13
15
|
super(cdr);
|
|
@@ -17,6 +19,7 @@ export class FormlyViewDocumentsComponent extends BaseFormlyControlComponent {
|
|
|
17
19
|
this.currentIndex = 0;
|
|
18
20
|
this.currentPdf = '';
|
|
19
21
|
this.cachedDocuments = {};
|
|
22
|
+
this.docError = null;
|
|
20
23
|
}
|
|
21
24
|
onInit() {
|
|
22
25
|
if (this.isDisplayMode === true) {
|
|
@@ -46,7 +49,7 @@ export class FormlyViewDocumentsComponent extends BaseFormlyControlComponent {
|
|
|
46
49
|
},
|
|
47
50
|
error: (err) => {
|
|
48
51
|
this.isLoading = false;
|
|
49
|
-
this.
|
|
52
|
+
this.docError = this.getErrorTranslationMessage('failToView');
|
|
50
53
|
this.cdr.detectChanges();
|
|
51
54
|
},
|
|
52
55
|
});
|
|
@@ -69,6 +72,7 @@ export class FormlyViewDocumentsComponent extends BaseFormlyControlComponent {
|
|
|
69
72
|
return list;
|
|
70
73
|
}
|
|
71
74
|
retry() {
|
|
75
|
+
this.docError = null;
|
|
72
76
|
this.getDocuments();
|
|
73
77
|
}
|
|
74
78
|
onPageSelected() {
|
|
@@ -105,8 +109,8 @@ export class FormlyViewDocumentsComponent extends BaseFormlyControlComponent {
|
|
|
105
109
|
}
|
|
106
110
|
},
|
|
107
111
|
error: (err) => {
|
|
108
|
-
this.dialog.popErrorTranslation(this.controlData.errorsTranslations, this.langIso, 'failToView');
|
|
109
112
|
this.isLoading = false;
|
|
113
|
+
this.docError = this.getErrorTranslationMessage('failToView');
|
|
110
114
|
this.cdr.detectChanges();
|
|
111
115
|
},
|
|
112
116
|
});
|
|
@@ -157,8 +161,8 @@ export class FormlyViewDocumentsComponent extends BaseFormlyControlComponent {
|
|
|
157
161
|
});
|
|
158
162
|
},
|
|
159
163
|
error: (err) => {
|
|
160
|
-
this.dialog.popErrorTranslation(this.controlData.errorsTranslations, this.langIso, 'failToView');
|
|
161
164
|
this.isLoading = false;
|
|
165
|
+
this.docError = this.getErrorTranslationMessage('failToView');
|
|
162
166
|
this.cdr.detectChanges();
|
|
163
167
|
},
|
|
164
168
|
});
|
|
@@ -236,10 +240,10 @@ export class FormlyViewDocumentsComponent extends BaseFormlyControlComponent {
|
|
|
236
240
|
}
|
|
237
241
|
}
|
|
238
242
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormlyViewDocumentsComponent, deps: [{ token: i1.ApplicationDataService }, { token: i2.DialogService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
239
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: FormlyViewDocumentsComponent, selector: "app-formly-view-documents", usesInheritance: true, ngImport: i0, template: "<
|
|
243
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: FormlyViewDocumentsComponent, selector: "app-formly-view-documents", usesInheritance: true, ngImport: i0, template: "<div class=\"view-docs-container\">\n <!-- Empty State -->\n <div class=\"view-docs-empty\" *ngIf=\"!isLoading && (!documents || documents.length === 0) && !docError\">\n <mat-icon class=\"empty-icon\">description</mat-icon>\n <p class=\"empty-text\">{{ getErrorTranslationMessage(\"noDocumentsToShow\") }}</p>\n </div>\n\n <!-- Error State -->\n <div class=\"view-docs-error\" *ngIf=\"docError\" role=\"alert\" aria-live=\"assertive\">\n <mat-icon>error_outline</mat-icon>\n <span>{{ docError }}</span>\n <button mat-stroked-button (click)=\"retry()\" class=\"retry-btn\">\n <mat-icon>refresh</mat-icon>\n Retry\n </button>\n </div>\n\n <!-- Loading State -->\n <div class=\"view-docs-loading\" *ngIf=\"isLoading\">\n <mat-progress-bar mode=\"indeterminate\"></mat-progress-bar>\n </div>\n\n <!-- Document Viewer -->\n <div class=\"view-docs-content\" *ngIf=\"!isLoading && documents && documents.length > 0 && !docError\">\n <!-- Navigation Bar -->\n <div class=\"doc-nav\">\n <button mat-icon-button\n (click)=\"prevDocument()\"\n [disabled]=\"!canGoBack\"\n class=\"doc-nav__btn\">\n <mat-icon>chevron_left</mat-icon>\n </button>\n <div class=\"doc-nav__info\">\n <p class=\"doc-nav__name\" *ngIf=\"currentDocument\">{{ currentDocument.name }}</p>\n <p class=\"doc-nav__counter\">{{ currentIndex + 1 }} / {{ documents.length }}</p>\n </div>\n <button mat-icon-button\n (click)=\"nextDocument()\"\n [disabled]=\"!canGoNext\"\n class=\"doc-nav__btn\">\n <mat-icon>chevron_right</mat-icon>\n </button>\n </div>\n\n <!-- PDF Viewer -->\n <div class=\"doc-viewer\">\n <pdf-viewer [src]=\"currentPdf\"\n [render-text]=\"true\"\n [original-size]=\"false\"\n [external-link-target]=\"'blank'\"\n class=\"pdf-viewer\"></pdf-viewer>\n </div>\n </div>\n</div>\n", styles: ["@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.view-docs-container{max-width:800px;margin:0 auto 16px;padding:24px;background-color:#fff;border-radius:7px;box-shadow:0 2px 12px #00000014}@media (max-width: 600px){.view-docs-container{padding:16px}}.view-docs-empty{animation:fadeIn .3s ease-out;display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 16px;text-align:center}.empty-icon{font-size:48px;width:48px;height:48px;color:#a1aab4}.empty-text{font-size:14px;color:#5a6a85;margin:0}.view-docs-error{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fa896b14;border:1px solid #fa896b;border-radius:7px;color:#2a3547;text-align:left}.view-docs-error>mat-icon{color:#fa896b;flex-shrink:0}.view-docs-error>span{flex:1;font-size:14px}@media (max-width: 600px){.view-docs-error{flex-wrap:wrap}.view-docs-error .retry-btn{width:100%;justify-content:center}}.retry-btn{display:flex;align-items:center;gap:6px;min-height:36px;border-radius:7px;flex-shrink:0}.view-docs-loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 0}.view-docs-loading mat-progress-bar{width:100%;border-radius:7px}.view-docs-content{animation:fadeIn .3s ease-out}.doc-nav{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:16px}@media (max-width: 600px){.doc-nav{gap:8px}}.doc-nav__btn{color:#5d87ff;flex-shrink:0}.doc-nav__btn:disabled{color:#ccc}.doc-nav__info{display:flex;flex-direction:column;align-items:center;min-width:0}.doc-nav__name{font-size:14px;font-weight:600;color:#2a3547;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:400px}@media (max-width: 600px){.doc-nav__name{max-width:200px;font-size:13px}}.doc-nav__counter{font-size:12px;color:#a1aab4;margin:2px 0 0}.doc-viewer{border:1px solid #e5eaef;border-radius:7px;overflow:hidden}.pdf-viewer{width:100%;height:70vh;max-height:900px;min-height:400px;overflow:auto}@media (max-width: 600px){.pdf-viewer{height:60vh;min-height:300px}}:host-context(.dark-theme) .view-docs-container{background-color:#2a3447;box-shadow:0 2px 12px #0000004d}:host-context(.dark-theme) .doc-nav__name{color:#ffffffde}:host-context(.dark-theme) .doc-nav__counter{color:#fff6}:host-context(.dark-theme) .doc-nav__btn{color:#5d87ff}:host-context(.dark-theme) .doc-nav__btn:disabled{color:#465670}:host-context(.dark-theme) .empty-icon{color:#fff6}:host-context(.dark-theme) .empty-text{color:#fff9}:host-context(.dark-theme) .doc-viewer{border-color:#333f55}:host-context(.dark-theme) .view-docs-error{background:#fa896b1a;color:#ffffffde}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.PdfViewerComponent, selector: "pdf-viewer", inputs: ["src", "c-maps-url", "page", "render-text", "render-text-mode", "original-size", "show-all", "stick-to-page", "zoom", "zoom-scale", "rotation", "external-link-target", "autoresize", "fit-to-page", "show-borders"], outputs: ["after-load-complete", "page-rendered", "pages-initialized", "text-layer-rendered", "error", "on-progress", "pageChange"] }, { kind: "component", type: i5.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i5.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i7.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }] }); }
|
|
240
244
|
}
|
|
241
245
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormlyViewDocumentsComponent, decorators: [{
|
|
242
246
|
type: Component,
|
|
243
|
-
args: [{ selector: 'app-formly-view-documents', template: "<
|
|
247
|
+
args: [{ selector: 'app-formly-view-documents', template: "<div class=\"view-docs-container\">\n <!-- Empty State -->\n <div class=\"view-docs-empty\" *ngIf=\"!isLoading && (!documents || documents.length === 0) && !docError\">\n <mat-icon class=\"empty-icon\">description</mat-icon>\n <p class=\"empty-text\">{{ getErrorTranslationMessage(\"noDocumentsToShow\") }}</p>\n </div>\n\n <!-- Error State -->\n <div class=\"view-docs-error\" *ngIf=\"docError\" role=\"alert\" aria-live=\"assertive\">\n <mat-icon>error_outline</mat-icon>\n <span>{{ docError }}</span>\n <button mat-stroked-button (click)=\"retry()\" class=\"retry-btn\">\n <mat-icon>refresh</mat-icon>\n Retry\n </button>\n </div>\n\n <!-- Loading State -->\n <div class=\"view-docs-loading\" *ngIf=\"isLoading\">\n <mat-progress-bar mode=\"indeterminate\"></mat-progress-bar>\n </div>\n\n <!-- Document Viewer -->\n <div class=\"view-docs-content\" *ngIf=\"!isLoading && documents && documents.length > 0 && !docError\">\n <!-- Navigation Bar -->\n <div class=\"doc-nav\">\n <button mat-icon-button\n (click)=\"prevDocument()\"\n [disabled]=\"!canGoBack\"\n class=\"doc-nav__btn\">\n <mat-icon>chevron_left</mat-icon>\n </button>\n <div class=\"doc-nav__info\">\n <p class=\"doc-nav__name\" *ngIf=\"currentDocument\">{{ currentDocument.name }}</p>\n <p class=\"doc-nav__counter\">{{ currentIndex + 1 }} / {{ documents.length }}</p>\n </div>\n <button mat-icon-button\n (click)=\"nextDocument()\"\n [disabled]=\"!canGoNext\"\n class=\"doc-nav__btn\">\n <mat-icon>chevron_right</mat-icon>\n </button>\n </div>\n\n <!-- PDF Viewer -->\n <div class=\"doc-viewer\">\n <pdf-viewer [src]=\"currentPdf\"\n [render-text]=\"true\"\n [original-size]=\"false\"\n [external-link-target]=\"'blank'\"\n class=\"pdf-viewer\"></pdf-viewer>\n </div>\n </div>\n</div>\n", styles: ["@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.view-docs-container{max-width:800px;margin:0 auto 16px;padding:24px;background-color:#fff;border-radius:7px;box-shadow:0 2px 12px #00000014}@media (max-width: 600px){.view-docs-container{padding:16px}}.view-docs-empty{animation:fadeIn .3s ease-out;display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 16px;text-align:center}.empty-icon{font-size:48px;width:48px;height:48px;color:#a1aab4}.empty-text{font-size:14px;color:#5a6a85;margin:0}.view-docs-error{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fa896b14;border:1px solid #fa896b;border-radius:7px;color:#2a3547;text-align:left}.view-docs-error>mat-icon{color:#fa896b;flex-shrink:0}.view-docs-error>span{flex:1;font-size:14px}@media (max-width: 600px){.view-docs-error{flex-wrap:wrap}.view-docs-error .retry-btn{width:100%;justify-content:center}}.retry-btn{display:flex;align-items:center;gap:6px;min-height:36px;border-radius:7px;flex-shrink:0}.view-docs-loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 0}.view-docs-loading mat-progress-bar{width:100%;border-radius:7px}.view-docs-content{animation:fadeIn .3s ease-out}.doc-nav{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:16px}@media (max-width: 600px){.doc-nav{gap:8px}}.doc-nav__btn{color:#5d87ff;flex-shrink:0}.doc-nav__btn:disabled{color:#ccc}.doc-nav__info{display:flex;flex-direction:column;align-items:center;min-width:0}.doc-nav__name{font-size:14px;font-weight:600;color:#2a3547;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:400px}@media (max-width: 600px){.doc-nav__name{max-width:200px;font-size:13px}}.doc-nav__counter{font-size:12px;color:#a1aab4;margin:2px 0 0}.doc-viewer{border:1px solid #e5eaef;border-radius:7px;overflow:hidden}.pdf-viewer{width:100%;height:70vh;max-height:900px;min-height:400px;overflow:auto}@media (max-width: 600px){.pdf-viewer{height:60vh;min-height:300px}}:host-context(.dark-theme) .view-docs-container{background-color:#2a3447;box-shadow:0 2px 12px #0000004d}:host-context(.dark-theme) .doc-nav__name{color:#ffffffde}:host-context(.dark-theme) .doc-nav__counter{color:#fff6}:host-context(.dark-theme) .doc-nav__btn{color:#5d87ff}:host-context(.dark-theme) .doc-nav__btn:disabled{color:#465670}:host-context(.dark-theme) .empty-icon{color:#fff6}:host-context(.dark-theme) .empty-text{color:#fff9}:host-context(.dark-theme) .doc-viewer{border-color:#333f55}:host-context(.dark-theme) .view-docs-error{background:#fa896b1a;color:#ffffffde}\n"] }]
|
|
244
248
|
}], ctorParameters: () => [{ type: i1.ApplicationDataService }, { type: i2.DialogService }, { type: i0.ChangeDetectorRef }] });
|
|
245
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-view-documents.component.js","sourceRoot":"","sources":["../../../../../../projects/origin-form/src/lib/formly/formly-view-documents/formly-view-documents.component.ts","../../../../../../projects/origin-form/src/lib/formly/formly-view-documents/formly-view-documents.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component } from '@angular/core';\nimport { ApplicationDataService } from '../../services/applicationData.service';\nimport { DialogService } from '../../services/dialog.service';\nimport { ApiDocumentRequest, ApplicationGetGeneratedDocumentsDto, ConvertDocumentToPdfRequest, GeneratedDocument } from '../../models/application.model';\nimport { Utils } from '../../others/utils';\nimport { firstValueFrom } from 'rxjs';\nimport { BaseFormlyControlComponent } from '../baseFormlyControlComponent';\n\n@Component({\n  selector: 'app-formly-view-documents',\n  templateUrl: './formly-view-documents.component.html',\n  styleUrl: './formly-view-documents.component.scss',\n})\nexport class FormlyViewDocumentsComponent extends BaseFormlyControlComponent {\n  documents: GeneratedDocument[] = [];\n  isDownloading: boolean;\n  currentIndex: number = 0;\n  canGoBack: boolean;\n  canGoNext: boolean;\n\n  currentPdf: any = '';\n  currentDocument: GeneratedDocument;\n  cachedDocuments: any = {};\n\n  constructor(\n    private appDataService: ApplicationDataService,\n    private dialog: DialogService,\n    cdr: ChangeDetectorRef\n  ) {\n    super(cdr);\n  }\n\n  override onInit() {\n    if (this.isDisplayMode === true) {\n      this.getDocuments();\n    }\n  }\n\n  getDocuments() {\n    const configDocs = this.controlData?.specificControlData?.documents;\n    if (configDocs) {\n      this.isLoading = true;\n      let cmd: ApplicationGetGeneratedDocumentsDto = {\n        appDataId: this.appDataId,\n        controlId: this.controlData.identifier,\n        isDisplayMode: this.isDisplayMode,\n        appConfigurationUUID: this.appId,\n        environment: this.env,\n      };\n\n      this.appDataService.getGenerateDocuments(cmd).subscribe({\n        next: (result) => {\n          this.isLoading = false;\n          this.documents = this.orderDocumentsAsConfigured(result);\n          if (this.documents && this.documents.length > 0) {\n            this.showDocument(this.documents[0]);\n          }\n          this.checkCanGoBackNext();\n          this.cdr.detectChanges();\n        },\n        error: (err) => {\n          this.isLoading = false;\n\n          this.dialog.popErrorTranslation(\n            this.controlData.errorsTranslations,\n            this.langIso,\n            'failToView'\n          );\n\n          this.cdr.detectChanges();\n        },\n      });\n    }\n    this.cdr.detectChanges();\n  }\n\n  orderDocumentsAsConfigured(\n    documents: GeneratedDocument[]\n  ): GeneratedDocument[] {\n    let list: GeneratedDocument[] = [];\n    if (documents) {\n      const configuradDocuments =\n        this.controlData?.specificControlData?.documents;\n      if (configuradDocuments) {\n        configuradDocuments.forEach((d: any) => {\n          const found = documents.find((f: any) => f.documentId === d.id);\n          if (found) {\n            list.push(found);\n          }\n        });\n      }\n    }\n    return list;\n  }\n\n  retry() {\n    this.getDocuments();\n  }\n\n  override onPageSelected() {\n    this.getDocuments();\n  }\n\n  async showDocument(doc: GeneratedDocument) {\n    this.currentDocument = doc;\n    const cached = this.cachedDocuments[doc.documentId];\n    if (cached) {\n      this.currentPdf = cached;\n    } else {\n      this.isLoading = true;\n      if (doc.isApiDocument === true) {\n        let apiRequest: ApiDocumentRequest = {\n          appDataId: this.appDataId,\n          documentId: doc.documentId,\n        };\n        this.appDataService.doDocumentRequest(apiRequest).subscribe({\n          next: (docs) => {\n            if (docs && docs.length > 0) {\n              docs.forEach((d) => {\n                const b64 = Utils.base64toBlob(d.content);\n                this.blobToArrayBuffer(b64).then((r) => {\n                  if (d.documentId === doc.documentId) {\n                    this.setCurrentDocument(doc.documentId, r);\n                  }\n                  this.cachedDocuments[d.documentId] = r;\n                });\n              });\n            } else {\n              this.dialog.popErrorTranslation(\n                this.controlData.errorsTranslations,\n                this.langIso,\n                'noDocumentsToShow'\n              );\n            }\n          },\n          error: (err) => {\n            this.dialog.popErrorTranslation(\n              this.controlData.errorsTranslations,\n              this.langIso,\n              'failToView'\n            );\n            this.isLoading = false;\n            this.cdr.detectChanges();\n          },\n        });\n      } else if ((doc as any).content) {\n        // Document has content directly available - convert to blob\n        let content = (doc as any).content;\n\n        // Check if content is a data URL and extract the base64 part\n        if (content.startsWith('data:')) {\n          const base64Start = content.indexOf(',');\n          if (base64Start !== -1) {\n            content = content.substring(base64Start + 1);\n          }\n        }\n\n        // Check if document needs PDF conversion\n        const originalContent = (doc as any).content;\n        const isPdf =\n          originalContent.includes('data:application/pdf') ||\n          originalContent.includes('application/pdf');\n\n        if (!isPdf) {\n          // For non-PDF documents, we need to convert to PDF or handle differently\n          console.warn(\n            'Non-PDF document detected. Converting to PDF...',\n            doc.name\n          );\n          // Call backend conversion API\n          this.convertToPdf(content, doc).then((pdfContent) => {\n            if (pdfContent) {\n              this.setCurrentDocument(doc.documentId, pdfContent);\n            } else {\n              this.isLoading = false;\n              this.cdr.detectChanges();\n            }\n          });\n        } else {\n          const b64 = Utils.base64toBlob(content);\n          this.blobToArrayBuffer(b64).then((r) => {\n            this.setCurrentDocument(doc.documentId, r);\n          });\n        }\n      } else {\n        // Download file case\n        this.appDataService\n          .downloadFile(this.props['appDataId'], doc.documentId, doc.fileName)\n          .subscribe({\n            next: (data) => {\n              this.blobToArrayBuffer(data).then((r) => {\n                this.setCurrentDocument(doc.documentId, r);\n              });\n            },\n            error: (err) => {\n              this.dialog.popErrorTranslation(\n                this.controlData.errorsTranslations,\n                this.langIso,\n                'failToView'\n              );\n              this.isLoading = false;\n              this.cdr.detectChanges();\n            },\n          });\n      }\n    }\n  }\n\n  setCurrentDocument(documentId: string, r: any) {\n    this.cachedDocuments[documentId] = r;\n    this.currentPdf = r;\n    this.isLoading = false;\n    this.cdr.detectChanges();\n  }\n\n  blobToArrayBuffer(blob: any) {\n    return new Promise((resolve, _) => {\n      const reader = new FileReader();\n      reader.onloadend = () => resolve(reader.result);\n      reader.readAsDataURL(blob);\n    });\n  }\n\n  nextDocument() {\n    if (this.currentIndex < this.documents.length) {\n      this.currentIndex++;\n      this.showDocument(this.documents[this.currentIndex]);\n    }\n    this.checkCanGoBackNext();\n  }\n\n  prevDocument() {\n    if (this.currentIndex >= 0) {\n      this.currentIndex--;\n      this.showDocument(this.documents[this.currentIndex]);\n    }\n    this.checkCanGoBackNext();\n  }\n\n  checkCanGoBackNext() {\n    if (this.currentIndex === 0) {\n      this.canGoBack = false;\n    } else {\n      this.canGoBack = true;\n    }\n    if (this.currentIndex < this.documents.length - 1) {\n      this.canGoNext = true;\n    } else {\n      this.canGoNext = false;\n    }\n  }\n\n  private async convertToPdf(\n    content: string,\n    doc: GeneratedDocument\n  ): Promise<any> {\n    // Call backend API to convert document to PDF\n    try {\n      const conversionRequest: ConvertDocumentToPdfRequest = {\n        content: content,\n        fileName: doc.name,\n        documentId: doc.documentId,\n        appDataId: this.appDataId,\n        appConfigurationUUID: this.appId,\n        environment: this.env,\n      };\n\n      const response = await firstValueFrom(\n        this.appDataService.convertDocumentToPdf(conversionRequest)\n      );\n\n      if (response?.success && response.pdfContent) {\n        // Convert PDF base64 to blob and return\n        const pdfBlob = Utils.base64toBlob(response.pdfContent);\n        return this.blobToArrayBuffer(pdfBlob);\n      } else {\n        console.error('PDF conversion failed:', response?.errorMessage);\n        this.dialog.popError(\n          response?.errorMessage || 'Failed to convert document to PDF'\n        );\n        return null;\n      }\n    } catch (error) {\n      console.error('PDF conversion failed:', error);\n      this.dialog.popError('Failed to convert document to PDF');\n      return null;\n    }\n  }\n}\n","<p *ngIf=\"isLoading === false && (!documents || documents.length === 0)\">\n  {{ getErrorTranslationMessage(\"noDocumentsToShow\") }}\n</p>\n\n<div class=\"buttons-container\">\n  <button (click)=\"prevDocument()\"\n          [disabled]=\"!canGoBack\"\n          class=\"nav-button larger-width-nav-buttons\">\n    &#8592;\n  </button>\n\n  <p class=\"file-info font-paragraph\" *ngIf=\"currentDocument\">\n    {{ this.currentDocument.name }}\n  </p>\n\n  <button (click)=\"nextDocument()\"\n          [disabled]=\"!canGoNext\"\n          class=\"nav-button larger-width-nav-buttons\">\n    &#8594;\n  </button>\n</div>\n\n<mat-spinner *ngIf=\"isLoading === true\" class=\"m-x-auto\"></mat-spinner>\n<pdf-viewer *ngIf=\"isLoading === false\"\n            [src]=\"currentPdf\"\n            [render-text]=\"true\"\n            [original-size]=\"false\"\n            [external-link-target]=\"'blank'\"\n            class=\"pdf-viewer\"></pdf-viewer>\n"]}
|
|
249
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-view-documents.component.js","sourceRoot":"","sources":["../../../../../../projects/origin-form/src/lib/formly/formly-view-documents/formly-view-documents.component.ts","../../../../../../projects/origin-form/src/lib/formly/formly-view-documents/formly-view-documents.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component } from '@angular/core';\nimport { ApplicationDataService } from '../../services/applicationData.service';\nimport { DialogService } from '../../services/dialog.service';\nimport { ApiDocumentRequest, ApplicationGetGeneratedDocumentsDto, ConvertDocumentToPdfRequest, GeneratedDocument } from '../../models/application.model';\nimport { Utils } from '../../others/utils';\nimport { firstValueFrom } from 'rxjs';\nimport { BaseFormlyControlComponent } from '../baseFormlyControlComponent';\n\n@Component({\n  selector: 'app-formly-view-documents',\n  templateUrl: './formly-view-documents.component.html',\n  styleUrl: './formly-view-documents.component.scss',\n})\nexport class FormlyViewDocumentsComponent extends BaseFormlyControlComponent {\n  documents: GeneratedDocument[] = [];\n  isDownloading: boolean;\n  currentIndex: number = 0;\n  canGoBack: boolean;\n  canGoNext: boolean;\n\n  currentPdf: any = '';\n  currentDocument: GeneratedDocument;\n  cachedDocuments: any = {};\n  docError: string | null = null;\n\n  constructor(\n    private appDataService: ApplicationDataService,\n    private dialog: DialogService,\n    cdr: ChangeDetectorRef\n  ) {\n    super(cdr);\n  }\n\n  override onInit() {\n    if (this.isDisplayMode === true) {\n      this.getDocuments();\n    }\n  }\n\n  getDocuments() {\n    const configDocs = this.controlData?.specificControlData?.documents;\n    if (configDocs) {\n      this.isLoading = true;\n      let cmd: ApplicationGetGeneratedDocumentsDto = {\n        appDataId: this.appDataId,\n        controlId: this.controlData.identifier,\n        isDisplayMode: this.isDisplayMode,\n        appConfigurationUUID: this.appId,\n        environment: this.env,\n      };\n\n      this.appDataService.getGenerateDocuments(cmd).subscribe({\n        next: (result) => {\n          this.isLoading = false;\n          this.documents = this.orderDocumentsAsConfigured(result);\n          if (this.documents && this.documents.length > 0) {\n            this.showDocument(this.documents[0]);\n          }\n          this.checkCanGoBackNext();\n          this.cdr.detectChanges();\n        },\n        error: (err) => {\n          this.isLoading = false;\n          this.docError = this.getErrorTranslationMessage('failToView');\n          this.cdr.detectChanges();\n        },\n      });\n    }\n    this.cdr.detectChanges();\n  }\n\n  orderDocumentsAsConfigured(\n    documents: GeneratedDocument[]\n  ): GeneratedDocument[] {\n    let list: GeneratedDocument[] = [];\n    if (documents) {\n      const configuradDocuments =\n        this.controlData?.specificControlData?.documents;\n      if (configuradDocuments) {\n        configuradDocuments.forEach((d: any) => {\n          const found = documents.find((f: any) => f.documentId === d.id);\n          if (found) {\n            list.push(found);\n          }\n        });\n      }\n    }\n    return list;\n  }\n\n  retry() {\n    this.docError = null;\n    this.getDocuments();\n  }\n\n  override onPageSelected() {\n    this.getDocuments();\n  }\n\n  async showDocument(doc: GeneratedDocument) {\n    this.currentDocument = doc;\n    const cached = this.cachedDocuments[doc.documentId];\n    if (cached) {\n      this.currentPdf = cached;\n    } else {\n      this.isLoading = true;\n      if (doc.isApiDocument === true) {\n        let apiRequest: ApiDocumentRequest = {\n          appDataId: this.appDataId,\n          documentId: doc.documentId,\n        };\n        this.appDataService.doDocumentRequest(apiRequest).subscribe({\n          next: (docs) => {\n            if (docs && docs.length > 0) {\n              docs.forEach((d) => {\n                const b64 = Utils.base64toBlob(d.content);\n                this.blobToArrayBuffer(b64).then((r) => {\n                  if (d.documentId === doc.documentId) {\n                    this.setCurrentDocument(doc.documentId, r);\n                  }\n                  this.cachedDocuments[d.documentId] = r;\n                });\n              });\n            } else {\n              this.dialog.popErrorTranslation(\n                this.controlData.errorsTranslations,\n                this.langIso,\n                'noDocumentsToShow'\n              );\n            }\n          },\n          error: (err) => {\n            this.isLoading = false;\n            this.docError = this.getErrorTranslationMessage('failToView');\n            this.cdr.detectChanges();\n          },\n        });\n      } else if ((doc as any).content) {\n        // Document has content directly available - convert to blob\n        let content = (doc as any).content;\n\n        // Check if content is a data URL and extract the base64 part\n        if (content.startsWith('data:')) {\n          const base64Start = content.indexOf(',');\n          if (base64Start !== -1) {\n            content = content.substring(base64Start + 1);\n          }\n        }\n\n        // Check if document needs PDF conversion\n        const originalContent = (doc as any).content;\n        const isPdf =\n          originalContent.includes('data:application/pdf') ||\n          originalContent.includes('application/pdf');\n\n        if (!isPdf) {\n          // For non-PDF documents, we need to convert to PDF or handle differently\n          console.warn(\n            'Non-PDF document detected. Converting to PDF...',\n            doc.name\n          );\n          // Call backend conversion API\n          this.convertToPdf(content, doc).then((pdfContent) => {\n            if (pdfContent) {\n              this.setCurrentDocument(doc.documentId, pdfContent);\n            } else {\n              this.isLoading = false;\n              this.cdr.detectChanges();\n            }\n          });\n        } else {\n          const b64 = Utils.base64toBlob(content);\n          this.blobToArrayBuffer(b64).then((r) => {\n            this.setCurrentDocument(doc.documentId, r);\n          });\n        }\n      } else {\n        // Download file case\n        this.appDataService\n          .downloadFile(this.props['appDataId'], doc.documentId, doc.fileName)\n          .subscribe({\n            next: (data) => {\n              this.blobToArrayBuffer(data).then((r) => {\n                this.setCurrentDocument(doc.documentId, r);\n              });\n            },\n            error: (err) => {\n              this.isLoading = false;\n              this.docError = this.getErrorTranslationMessage('failToView');\n              this.cdr.detectChanges();\n            },\n          });\n      }\n    }\n  }\n\n  setCurrentDocument(documentId: string, r: any) {\n    this.cachedDocuments[documentId] = r;\n    this.currentPdf = r;\n    this.isLoading = false;\n    this.cdr.detectChanges();\n  }\n\n  blobToArrayBuffer(blob: any) {\n    return new Promise((resolve, _) => {\n      const reader = new FileReader();\n      reader.onloadend = () => resolve(reader.result);\n      reader.readAsDataURL(blob);\n    });\n  }\n\n  nextDocument() {\n    if (this.currentIndex < this.documents.length) {\n      this.currentIndex++;\n      this.showDocument(this.documents[this.currentIndex]);\n    }\n    this.checkCanGoBackNext();\n  }\n\n  prevDocument() {\n    if (this.currentIndex >= 0) {\n      this.currentIndex--;\n      this.showDocument(this.documents[this.currentIndex]);\n    }\n    this.checkCanGoBackNext();\n  }\n\n  checkCanGoBackNext() {\n    if (this.currentIndex === 0) {\n      this.canGoBack = false;\n    } else {\n      this.canGoBack = true;\n    }\n    if (this.currentIndex < this.documents.length - 1) {\n      this.canGoNext = true;\n    } else {\n      this.canGoNext = false;\n    }\n  }\n\n  private async convertToPdf(\n    content: string,\n    doc: GeneratedDocument\n  ): Promise<any> {\n    // Call backend API to convert document to PDF\n    try {\n      const conversionRequest: ConvertDocumentToPdfRequest = {\n        content: content,\n        fileName: doc.name,\n        documentId: doc.documentId,\n        appDataId: this.appDataId,\n        appConfigurationUUID: this.appId,\n        environment: this.env,\n      };\n\n      const response = await firstValueFrom(\n        this.appDataService.convertDocumentToPdf(conversionRequest)\n      );\n\n      if (response?.success && response.pdfContent) {\n        // Convert PDF base64 to blob and return\n        const pdfBlob = Utils.base64toBlob(response.pdfContent);\n        return this.blobToArrayBuffer(pdfBlob);\n      } else {\n        console.error('PDF conversion failed:', response?.errorMessage);\n        this.dialog.popError(\n          response?.errorMessage || 'Failed to convert document to PDF'\n        );\n        return null;\n      }\n    } catch (error) {\n      console.error('PDF conversion failed:', error);\n      this.dialog.popError('Failed to convert document to PDF');\n      return null;\n    }\n  }\n}\n","<div class=\"view-docs-container\">\n  <!-- Empty State -->\n  <div class=\"view-docs-empty\" *ngIf=\"!isLoading && (!documents || documents.length === 0) && !docError\">\n    <mat-icon class=\"empty-icon\">description</mat-icon>\n    <p class=\"empty-text\">{{ getErrorTranslationMessage(\"noDocumentsToShow\") }}</p>\n  </div>\n\n  <!-- Error State -->\n  <div class=\"view-docs-error\" *ngIf=\"docError\" role=\"alert\" aria-live=\"assertive\">\n    <mat-icon>error_outline</mat-icon>\n    <span>{{ docError }}</span>\n    <button mat-stroked-button (click)=\"retry()\" class=\"retry-btn\">\n      <mat-icon>refresh</mat-icon>\n      Retry\n    </button>\n  </div>\n\n  <!-- Loading State -->\n  <div class=\"view-docs-loading\" *ngIf=\"isLoading\">\n    <mat-progress-bar mode=\"indeterminate\"></mat-progress-bar>\n  </div>\n\n  <!-- Document Viewer -->\n  <div class=\"view-docs-content\" *ngIf=\"!isLoading && documents && documents.length > 0 && !docError\">\n    <!-- Navigation Bar -->\n    <div class=\"doc-nav\">\n      <button mat-icon-button\n              (click)=\"prevDocument()\"\n              [disabled]=\"!canGoBack\"\n              class=\"doc-nav__btn\">\n        <mat-icon>chevron_left</mat-icon>\n      </button>\n      <div class=\"doc-nav__info\">\n        <p class=\"doc-nav__name\" *ngIf=\"currentDocument\">{{ currentDocument.name }}</p>\n        <p class=\"doc-nav__counter\">{{ currentIndex + 1 }} / {{ documents.length }}</p>\n      </div>\n      <button mat-icon-button\n              (click)=\"nextDocument()\"\n              [disabled]=\"!canGoNext\"\n              class=\"doc-nav__btn\">\n        <mat-icon>chevron_right</mat-icon>\n      </button>\n    </div>\n\n    <!-- PDF Viewer -->\n    <div class=\"doc-viewer\">\n      <pdf-viewer [src]=\"currentPdf\"\n                  [render-text]=\"true\"\n                  [original-size]=\"false\"\n                  [external-link-target]=\"'blank'\"\n                  class=\"pdf-viewer\"></pdf-viewer>\n    </div>\n  </div>\n</div>\n"]}
|