@sunbird-cb/cbp-ai 0.0.1
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 +24 -0
- package/esm2022/lib/ai-cbp-routing.module.mjs +56 -0
- package/esm2022/lib/ai-cbp.component.mjs +14 -0
- package/esm2022/lib/ai-cbp.module.mjs +263 -0
- package/esm2022/lib/ai-cbp.service.mjs +14 -0
- package/esm2022/lib/components/add-course/add-course.component.mjs +444 -0
- package/esm2022/lib/components/add-designation/add-designation.component.mjs +460 -0
- package/esm2022/lib/components/add-personalisation/add-personalisation.component.mjs +33 -0
- package/esm2022/lib/components/approval-request-form/approval-request-form.component.mjs +392 -0
- package/esm2022/lib/components/approval-requests/approval-requests.component.mjs +398 -0
- package/esm2022/lib/components/dashboard/dashboard.component.mjs +265 -0
- package/esm2022/lib/components/delete-role-mapping/delete-role-mapping.component.mjs +53 -0
- package/esm2022/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.mjs +39 -0
- package/esm2022/lib/components/edit-cbp-plan/edit-cbp-plan.component.mjs +699 -0
- package/esm2022/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.mjs +188 -0
- package/esm2022/lib/components/generate-course-recommendation/generate-course-recommendation.component.mjs +1949 -0
- package/esm2022/lib/components/list-popup/list-popup.component.mjs +32 -0
- package/esm2022/lib/components/review-request/review-request.component.mjs +138 -0
- package/esm2022/lib/components/role-mapping-generation/role-mapping-generation.component.mjs +1082 -0
- package/esm2022/lib/components/role-mapping-list/role-mapping-list.component.mjs +714 -0
- package/esm2022/lib/components/suggest-more-courses/suggest-more-courses.component.mjs +370 -0
- package/esm2022/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.mjs +235 -0
- package/esm2022/lib/components/view-cbp-plan/view-cbp-plan.component.mjs +125 -0
- package/esm2022/lib/components/view-course-recommendation/view-course-recommendation.component.mjs +397 -0
- package/esm2022/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.mjs +883 -0
- package/esm2022/lib/modules/initial-screen/initial-screen.component.mjs +127 -0
- package/esm2022/lib/modules/shared/constant/app.constant.mjs +2036 -0
- package/esm2022/lib/modules/shared/directives/clickoutside.directive.mjs +38 -0
- package/esm2022/lib/modules/shared/directives/directive.module.mjs +21 -0
- package/esm2022/lib/modules/shared/pipes/order-by-name.pipe.mjs +23 -0
- package/esm2022/lib/modules/shared/services/event.service.mjs +24 -0
- package/esm2022/lib/modules/shared/services/events.mjs +125 -0
- package/esm2022/lib/modules/shared/services/init.service.mjs +41 -0
- package/esm2022/lib/modules/shared/services/role-mapping.service.mjs +261 -0
- package/esm2022/lib/modules/shared/services/shared.service.mjs +869 -0
- package/esm2022/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.mjs +53 -0
- package/esm2022/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.mjs +186 -0
- package/esm2022/lib/modules/upload-document-page/upload-document-page.component.mjs +367 -0
- package/esm2022/lib/pipe-public-URL/pipe-public-URL.module.mjs +20 -0
- package/esm2022/lib/pipe-public-URL/pipe-public-URL.pipe.mjs +23 -0
- package/esm2022/public-api.mjs +14 -0
- package/esm2022/sunbird-cb-cbp-ai.mjs +5 -0
- package/fesm2022/sunbird-cb-cbp-ai.mjs +12952 -0
- package/fesm2022/sunbird-cb-cbp-ai.mjs.map +1 -0
- package/index.d.ts +6 -0
- package/lib/ai-cbp-routing.module.d.ts +8 -0
- package/lib/ai-cbp-routing.module.d.ts.map +1 -0
- package/lib/ai-cbp.component.d.ts +7 -0
- package/lib/ai-cbp.component.d.ts.map +1 -0
- package/lib/ai-cbp.module.d.ts +68 -0
- package/lib/ai-cbp.module.d.ts.map +1 -0
- package/lib/ai-cbp.service.d.ts +7 -0
- package/lib/ai-cbp.service.d.ts.map +1 -0
- package/lib/components/add-course/add-course.component.d.ts +67 -0
- package/lib/components/add-course/add-course.component.d.ts.map +1 -0
- package/lib/components/add-designation/add-designation.component.d.ts +52 -0
- package/lib/components/add-designation/add-designation.component.d.ts.map +1 -0
- package/lib/components/add-personalisation/add-personalisation.component.d.ts +16 -0
- package/lib/components/add-personalisation/add-personalisation.component.d.ts.map +1 -0
- package/lib/components/approval-request-form/approval-request-form.component.d.ts +48 -0
- package/lib/components/approval-request-form/approval-request-form.component.d.ts.map +1 -0
- package/lib/components/approval-requests/approval-requests.component.d.ts +80 -0
- package/lib/components/approval-requests/approval-requests.component.d.ts.map +1 -0
- package/lib/components/dashboard/dashboard.component.d.ts +55 -0
- package/lib/components/dashboard/dashboard.component.d.ts.map +1 -0
- package/lib/components/delete-role-mapping/delete-role-mapping.component.d.ts +18 -0
- package/lib/components/delete-role-mapping/delete-role-mapping.component.d.ts.map +1 -0
- package/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.d.ts +18 -0
- package/lib/components/delete-role-mapping-popup/delete-role-mapping-popup.component.d.ts.map +1 -0
- package/lib/components/edit-cbp-plan/edit-cbp-plan.component.d.ts +94 -0
- package/lib/components/edit-cbp-plan/edit-cbp-plan.component.d.ts.map +1 -0
- package/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.d.ts +35 -0
- package/lib/components/gap-analysis-recommended-course/gap-analysis-recommended-course.component.d.ts.map +1 -0
- package/lib/components/generate-course-recommendation/generate-course-recommendation.component.d.ts +198 -0
- package/lib/components/generate-course-recommendation/generate-course-recommendation.component.d.ts.map +1 -0
- package/lib/components/list-popup/list-popup.component.d.ts +13 -0
- package/lib/components/list-popup/list-popup.component.d.ts.map +1 -0
- package/lib/components/review-request/review-request.component.d.ts +39 -0
- package/lib/components/review-request/review-request.component.d.ts.map +1 -0
- package/lib/components/role-mapping-generation/role-mapping-generation.component.d.ts +99 -0
- package/lib/components/role-mapping-generation/role-mapping-generation.component.d.ts.map +1 -0
- package/lib/components/role-mapping-list/role-mapping-list.component.d.ts +83 -0
- package/lib/components/role-mapping-list/role-mapping-list.component.d.ts.map +1 -0
- package/lib/components/suggest-more-courses/suggest-more-courses.component.d.ts +48 -0
- package/lib/components/suggest-more-courses/suggest-more-courses.component.d.ts.map +1 -0
- package/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.d.ts +41 -0
- package/lib/components/update-designation-hierarchy/update-designation-hierarchy.component.d.ts.map +1 -0
- package/lib/components/view-cbp-plan/view-cbp-plan.component.d.ts +29 -0
- package/lib/components/view-cbp-plan/view-cbp-plan.component.d.ts.map +1 -0
- package/lib/components/view-course-recommendation/view-course-recommendation.component.d.ts +49 -0
- package/lib/components/view-course-recommendation/view-course-recommendation.component.d.ts.map +1 -0
- package/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.d.ts +73 -0
- package/lib/components/view-final-cbp-plan/view-final-cbp-plan.component.d.ts.map +1 -0
- package/lib/modules/initial-screen/initial-screen.component.d.ts +85 -0
- package/lib/modules/initial-screen/initial-screen.component.d.ts.map +1 -0
- package/lib/modules/shared/constant/app.constant.d.ts +457 -0
- package/lib/modules/shared/constant/app.constant.d.ts.map +1 -0
- package/lib/modules/shared/directives/clickoutside.directive.d.ts +13 -0
- package/lib/modules/shared/directives/clickoutside.directive.d.ts.map +1 -0
- package/lib/modules/shared/directives/directive.module.d.ts +8 -0
- package/lib/modules/shared/directives/directive.module.d.ts.map +1 -0
- package/lib/modules/shared/pipes/order-by-name.pipe.d.ts +8 -0
- package/lib/modules/shared/pipes/order-by-name.pipe.d.ts.map +1 -0
- package/lib/modules/shared/services/event.service.d.ts +12 -0
- package/lib/modules/shared/services/event.service.d.ts.map +1 -0
- package/lib/modules/shared/services/events.d.ts +200 -0
- package/lib/modules/shared/services/events.d.ts.map +1 -0
- package/lib/modules/shared/services/init.service.d.ts +13 -0
- package/lib/modules/shared/services/init.service.d.ts.map +1 -0
- package/lib/modules/shared/services/role-mapping.service.d.ts +21 -0
- package/lib/modules/shared/services/role-mapping.service.d.ts.map +1 -0
- package/lib/modules/shared/services/shared.service.d.ts +108 -0
- package/lib/modules/shared/services/shared.service.d.ts.map +1 -0
- package/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.d.ts +14 -0
- package/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.d.ts.map +1 -0
- package/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.d.ts +29 -0
- package/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.d.ts.map +1 -0
- package/lib/modules/upload-document-page/upload-document-page.component.d.ts +64 -0
- package/lib/modules/upload-document-page/upload-document-page.component.d.ts.map +1 -0
- package/lib/pipe-public-URL/pipe-public-URL.module.d.ts +9 -0
- package/lib/pipe-public-URL/pipe-public-URL.module.d.ts.map +1 -0
- package/lib/pipe-public-URL/pipe-public-URL.pipe.d.ts +11 -0
- package/lib/pipe-public-URL/pipe-public-URL.pipe.d.ts.map +1 -0
- package/package.json +28 -0
- package/public-api.d.ts +11 -0
- package/public-api.d.ts.map +1 -0
- package/sunbird-cb-cbp-ai-0.0.1.tgz +0 -0
- package/sunbird-cb-cbp-ai.d.ts.map +1 -0
package/esm2022/lib/modules/upload-document-page/progress-dialog/progress-dialog.component.mjs
ADDED
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { Component, Inject } from '@angular/core';
|
|
2
|
+
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class ProgressDialogComponent {
|
|
5
|
+
constructor(data) {
|
|
6
|
+
this.data = data;
|
|
7
|
+
console.log('data--', data);
|
|
8
|
+
}
|
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ProgressDialogComponent, deps: [{ token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
10
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ProgressDialogComponent, selector: "app-progress-dialog", ngImport: i0, template: `
|
|
11
|
+
<div class="progress-container">
|
|
12
|
+
<h3>Processing Summaries</h3>
|
|
13
|
+
<p>{{ data.message }}</p>
|
|
14
|
+
<p>Please wait , it will take few minutes to complete</p>
|
|
15
|
+
<div class="progress-container">
|
|
16
|
+
<!-- Circular Spinner -->
|
|
17
|
+
<div class="spinner"></div>
|
|
18
|
+
|
|
19
|
+
<!-- Linear Progress Bar -->
|
|
20
|
+
<div class="linear-progress">
|
|
21
|
+
<div class="bar"></div>
|
|
22
|
+
</div>
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
</div>
|
|
26
|
+
</div>
|
|
27
|
+
`, isInline: true, styles: [".progress-container{padding:20px;width:auto;text-align:center}mat-progress-bar{margin-top:20px}.spinner{width:64px;height:64px;border-radius:50%;border:6px solid #e8e6ff;border-top-color:#5b5bf0;border-right-color:#8b7cf7;animation:spin 1.2s linear infinite;margin:0 auto 28px}@keyframes spin{to{transform:rotate(360deg)}}.linear-progress{position:relative;width:100%;height:8px;background:#e8e6ff;border-radius:4px;overflow:hidden;margin-bottom:24px}.linear-progress .bar{position:absolute;height:100%;width:40%;background:linear-gradient(90deg,#b8b1ff,#5b5bf0,#b8b1ff);animation:indeterminate 1.6s infinite ease-in-out}@keyframes indeterminate{0%{left:-40%}to{left:100%}}.label strong{font-size:18px;color:#2f2f44}.label p{margin-top:4px;font-size:14px;color:#6b6b8a}\n"] }); }
|
|
28
|
+
}
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ProgressDialogComponent, decorators: [{
|
|
30
|
+
type: Component,
|
|
31
|
+
args: [{ selector: 'app-progress-dialog', template: `
|
|
32
|
+
<div class="progress-container">
|
|
33
|
+
<h3>Processing Summaries</h3>
|
|
34
|
+
<p>{{ data.message }}</p>
|
|
35
|
+
<p>Please wait , it will take few minutes to complete</p>
|
|
36
|
+
<div class="progress-container">
|
|
37
|
+
<!-- Circular Spinner -->
|
|
38
|
+
<div class="spinner"></div>
|
|
39
|
+
|
|
40
|
+
<!-- Linear Progress Bar -->
|
|
41
|
+
<div class="linear-progress">
|
|
42
|
+
<div class="bar"></div>
|
|
43
|
+
</div>
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
</div>
|
|
47
|
+
</div>
|
|
48
|
+
`, styles: [".progress-container{padding:20px;width:auto;text-align:center}mat-progress-bar{margin-top:20px}.spinner{width:64px;height:64px;border-radius:50%;border:6px solid #e8e6ff;border-top-color:#5b5bf0;border-right-color:#8b7cf7;animation:spin 1.2s linear infinite;margin:0 auto 28px}@keyframes spin{to{transform:rotate(360deg)}}.linear-progress{position:relative;width:100%;height:8px;background:#e8e6ff;border-radius:4px;overflow:hidden;margin-bottom:24px}.linear-progress .bar{position:absolute;height:100%;width:40%;background:linear-gradient(90deg,#b8b1ff,#5b5bf0,#b8b1ff);animation:indeterminate 1.6s infinite ease-in-out}@keyframes indeterminate{0%{left:-40%}to{left:100%}}.label strong{font-size:18px;color:#2f2f44}.label p{margin-top:4px;font-size:14px;color:#6b6b8a}\n"] }]
|
|
49
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
50
|
+
type: Inject,
|
|
51
|
+
args: [MAT_DIALOG_DATA]
|
|
52
|
+
}] }]; } });
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3MtZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnJhcnkvc3VuYmlyZC1jYi9jYnAtYWkvc3JjL2xpYi9tb2R1bGVzL3VwbG9hZC1kb2N1bWVudC1wYWdlL3Byb2dyZXNzLWRpYWxvZy9wcm9ncmVzcy1kaWFsb2cuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7QUF3RzNELE1BQU0sT0FBTyx1QkFBdUI7SUFDbEMsWUFBNEMsSUFBMkM7UUFBM0MsU0FBSSxHQUFKLElBQUksQ0FBdUM7UUFDckYsT0FBTyxDQUFDLEdBQUcsQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLENBQUE7SUFDN0IsQ0FBQzsrR0FIVSx1QkFBdUIsa0JBQ2QsZUFBZTttR0FEeEIsdUJBQXVCLDJEQXBHeEI7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBaUJUOzs0RkFtRlUsdUJBQXVCO2tCQXRHbkMsU0FBUzsrQkFDRSxxQkFBcUIsWUFDckI7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBaUJUOzswQkFvRlksTUFBTTsyQkFBQyxlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1BVF9ESUFMT0dfREFUQSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC1wcm9ncmVzcy1kaWFsb2cnLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgY2xhc3M9XCJwcm9ncmVzcy1jb250YWluZXJcIj5cbiAgICAgIDxoMz5Qcm9jZXNzaW5nIFN1bW1hcmllczwvaDM+XG4gICAgICA8cD57eyBkYXRhLm1lc3NhZ2UgfX08L3A+XG4gICAgICA8cD5QbGVhc2Ugd2FpdCAsIGl0IHdpbGwgdGFrZSBmZXcgbWludXRlcyB0byBjb21wbGV0ZTwvcD5cbiAgICAgIDxkaXYgY2xhc3M9XCJwcm9ncmVzcy1jb250YWluZXJcIj5cbiAgICAgICAgPCEtLSBDaXJjdWxhciBTcGlubmVyIC0tPlxuICAgICAgICA8ZGl2IGNsYXNzPVwic3Bpbm5lclwiPjwvZGl2PlxuXG4gICAgICAgIDwhLS0gTGluZWFyIFByb2dyZXNzIEJhciAtLT5cbiAgICAgICAgPGRpdiBjbGFzcz1cImxpbmVhci1wcm9ncmVzc1wiPlxuICAgICAgICAgIDxkaXYgY2xhc3M9XCJiYXJcIj48L2Rpdj5cbiAgICAgICAgPC9kaXY+XG5cbiAgICAgICBcbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICBgLFxuICBzdHlsZXM6IFtgXG4gICAgLnByb2dyZXNzLWNvbnRhaW5lciB7XG4gICAgICBwYWRkaW5nOiAyMHB4O1xuICAgICAgd2lkdGg6IGF1dG87XG4gICAgICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gICAgfVxuICAgIG1hdC1wcm9ncmVzcy1iYXIge1xuICAgICAgbWFyZ2luLXRvcDogMjBweDtcbiAgICB9XG4gICBcblxuLyogPT09PT09PT09PT09PT09PT09PT09PT09PVxuICAgQ2lyY3VsYXIgU3Bpbm5lclxuPT09PT09PT09PT09PT09PT09PT09PT09PSAqL1xuLnNwaW5uZXIge1xuICB3aWR0aDogNjRweDtcbiAgaGVpZ2h0OiA2NHB4O1xuICBib3JkZXItcmFkaXVzOiA1MCU7XG4gIGJvcmRlcjogNnB4IHNvbGlkICNlOGU2ZmY7XG4gIGJvcmRlci10b3AtY29sb3I6ICM1YjViZjA7XG4gIGJvcmRlci1yaWdodC1jb2xvcjogIzhiN2NmNztcbiAgYW5pbWF0aW9uOiBzcGluIDEuMnMgbGluZWFyIGluZmluaXRlO1xuICBtYXJnaW46IDAgYXV0byAyOHB4O1xufVxuXG5Aa2V5ZnJhbWVzIHNwaW4ge1xuICAxMDAlIHtcbiAgICB0cmFuc2Zvcm06IHJvdGF0ZSgzNjBkZWcpO1xuICB9XG59XG5cbi8qID09PT09PT09PT09PT09PT09PT09PT09PT1cbiAgIExpbmVhciBQcm9ncmVzcyBCYXJcbj09PT09PT09PT09PT09PT09PT09PT09PT0gKi9cbi5saW5lYXItcHJvZ3Jlc3Mge1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHdpZHRoOiAxMDAlO1xuICBoZWlnaHQ6IDhweDtcbiAgYmFja2dyb3VuZDogI2U4ZTZmZjtcbiAgYm9yZGVyLXJhZGl1czogNHB4O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICBtYXJnaW4tYm90dG9tOiAyNHB4O1xufVxuXG4ubGluZWFyLXByb2dyZXNzIC5iYXIge1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIGhlaWdodDogMTAwJTtcbiAgd2lkdGg6IDQwJTtcbiAgYmFja2dyb3VuZDogbGluZWFyLWdyYWRpZW50KFxuICAgIDkwZGVnLFxuICAgICNiOGIxZmYsXG4gICAgIzViNWJmMCxcbiAgICAjYjhiMWZmXG4gICk7XG4gIGFuaW1hdGlvbjogaW5kZXRlcm1pbmF0ZSAxLjZzIGluZmluaXRlIGVhc2UtaW4tb3V0O1xufVxuXG5Aa2V5ZnJhbWVzIGluZGV0ZXJtaW5hdGUge1xuICAwJSB7XG4gICAgbGVmdDogLTQwJTtcbiAgfVxuICAxMDAlIHtcbiAgICBsZWZ0OiAxMDAlO1xuICB9XG59XG5cbi8qID09PT09PT09PT09PT09PT09PT09PT09PT1cbiAgIFRleHRcbj09PT09PT09PT09PT09PT09PT09PT09PT0gKi9cbi5sYWJlbCBzdHJvbmcge1xuICBmb250LXNpemU6IDE4cHg7XG4gIGNvbG9yOiAjMmYyZjQ0O1xufVxuXG4ubGFiZWwgcCB7XG4gIG1hcmdpbi10b3A6IDRweDtcbiAgZm9udC1zaXplOiAxNHB4O1xuICBjb2xvcjogIzZiNmI4YTtcbn1cblxuICBgXVxufSlcbmV4cG9ydCBjbGFzcyBQcm9ncmVzc0RpYWxvZ0NvbXBvbmVudCB7XG4gIGNvbnN0cnVjdG9yKEBJbmplY3QoTUFUX0RJQUxPR19EQVRBKSBwdWJsaWMgZGF0YTogeyBwcm9ncmVzczogbnVtYmVyOyBtZXNzYWdlOiBzdHJpbmcgfSkge1xuICAgIGNvbnNvbGUubG9nKCdkYXRhLS0nLCBkYXRhKVxuICB9XG59Il19
|
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { ProgressDialogComponent } from '../progress-dialog/progress-dialog.component';
|
|
3
|
+
import { interval, forkJoin } from 'rxjs';
|
|
4
|
+
import { startWith, switchMap, takeWhile, tap } from 'rxjs/operators';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/material/dialog";
|
|
7
|
+
import * as i2 from "../../shared/services/shared.service";
|
|
8
|
+
import * as i3 from "@angular/material/snack-bar";
|
|
9
|
+
import * as i4 from "@angular/common";
|
|
10
|
+
import * as i5 from "@angular/material/legacy-button";
|
|
11
|
+
import * as i6 from "@angular/material/icon";
|
|
12
|
+
import * as i7 from "@angular/material/progress-spinner";
|
|
13
|
+
import * as i8 from "@angular/material/tooltip";
|
|
14
|
+
export class UploadDialogComponent {
|
|
15
|
+
constructor(dialogRef, sharedService, snackBar, dialog) {
|
|
16
|
+
this.dialogRef = dialogRef;
|
|
17
|
+
this.sharedService = sharedService;
|
|
18
|
+
this.snackBar = snackBar;
|
|
19
|
+
this.dialog = dialog;
|
|
20
|
+
this.MAX_FILES = 10;
|
|
21
|
+
this.documentName = '';
|
|
22
|
+
this.selectedFiles = [];
|
|
23
|
+
this.cbpFinalObj = {};
|
|
24
|
+
this.loading = false;
|
|
25
|
+
this.uploadedFileData = {};
|
|
26
|
+
this.cbpFinalObj = this.sharedService.getCBPPlanLocalStorage();
|
|
27
|
+
}
|
|
28
|
+
/** Already uploaded files count */
|
|
29
|
+
get uploadedCount() {
|
|
30
|
+
return this.cbpFinalObj?.documents?.length || 0;
|
|
31
|
+
}
|
|
32
|
+
/** Uploaded + newly selected */
|
|
33
|
+
get totalFileCount() {
|
|
34
|
+
return this.uploadedCount + this.selectedFiles.length;
|
|
35
|
+
}
|
|
36
|
+
onFileSelected(event) {
|
|
37
|
+
const input = event.target;
|
|
38
|
+
if (!input.files)
|
|
39
|
+
return;
|
|
40
|
+
const files = Array.from(input.files);
|
|
41
|
+
const allowedExtensions = ['pdf', 'doc', 'docx'];
|
|
42
|
+
for (const file of files) {
|
|
43
|
+
if (this.totalFileCount >= this.MAX_FILES) {
|
|
44
|
+
this.snackBar.open('You can upload a maximum of 10 documents.', 'X', {
|
|
45
|
+
duration: 3000,
|
|
46
|
+
panelClass: ['snackbar-error']
|
|
47
|
+
});
|
|
48
|
+
break;
|
|
49
|
+
}
|
|
50
|
+
const ext = file.name.split('.').pop()?.toLowerCase();
|
|
51
|
+
if (!ext || !allowedExtensions.includes(ext)) {
|
|
52
|
+
this.snackBar.open(`Invalid file type: ${file.name}`, 'X', { duration: 3000, panelClass: ['snackbar-error'] });
|
|
53
|
+
continue;
|
|
54
|
+
}
|
|
55
|
+
// Prevent duplicate selection
|
|
56
|
+
if (this.selectedFiles.some(f => f.name === file.name && f.size === file.size)) {
|
|
57
|
+
continue;
|
|
58
|
+
}
|
|
59
|
+
this.selectedFiles.push(file);
|
|
60
|
+
}
|
|
61
|
+
// Reset input so same file can be re-selected
|
|
62
|
+
input.value = '';
|
|
63
|
+
}
|
|
64
|
+
removeFile(index) {
|
|
65
|
+
this.selectedFiles.splice(index, 1);
|
|
66
|
+
}
|
|
67
|
+
// upload(): void {
|
|
68
|
+
// if (!this.documentName || this.selectedFiles.length === 0) {
|
|
69
|
+
// return;
|
|
70
|
+
// }
|
|
71
|
+
// if (this.totalFileCount > this.MAX_FILES) {
|
|
72
|
+
// this.snackBar.open('Maximum 10 documents allowed.', 'X', {
|
|
73
|
+
// duration: 3000,
|
|
74
|
+
// panelClass: ['snackbar-error']
|
|
75
|
+
// });
|
|
76
|
+
// return;
|
|
77
|
+
// }
|
|
78
|
+
// this.loading = true;
|
|
79
|
+
// const uploadNext = (index: number) => {
|
|
80
|
+
// if (index >= this.selectedFiles.length) {
|
|
81
|
+
// this.loading = false;
|
|
82
|
+
// this.dialogRef.close('close');
|
|
83
|
+
// return;
|
|
84
|
+
// }
|
|
85
|
+
// const file = this.selectedFiles[index];
|
|
86
|
+
// const reqBody = {
|
|
87
|
+
// state_center_id: this.cbpFinalObj?.ministry?.identifier,
|
|
88
|
+
// department_id: this.cbpFinalObj?.departments,
|
|
89
|
+
// documentName: this.documentName
|
|
90
|
+
// };
|
|
91
|
+
// this.sharedService.uploadDocument(reqBody, file).subscribe({
|
|
92
|
+
// next: (res) => {
|
|
93
|
+
// this.uploadedFileData = res;
|
|
94
|
+
// this.triggerFileSummary();
|
|
95
|
+
// uploadNext(index + 1);
|
|
96
|
+
// },
|
|
97
|
+
// error: (err) => {
|
|
98
|
+
// this.loading = false;
|
|
99
|
+
// this.snackBar.open(
|
|
100
|
+
// err?.error?.detail || 'Upload failed',
|
|
101
|
+
// 'X',
|
|
102
|
+
// { duration: 3000, panelClass: ['snackbar-error'] }
|
|
103
|
+
// );
|
|
104
|
+
// }
|
|
105
|
+
// });
|
|
106
|
+
// };
|
|
107
|
+
// uploadNext(0);
|
|
108
|
+
// }
|
|
109
|
+
upload() {
|
|
110
|
+
if (this.selectedFiles.length === 0) {
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
if (this.totalFileCount > this.MAX_FILES) {
|
|
114
|
+
this.snackBar.open('Maximum 10 documents allowed.', 'X', {
|
|
115
|
+
duration: 3000,
|
|
116
|
+
panelClass: ['snackbar-error']
|
|
117
|
+
});
|
|
118
|
+
return;
|
|
119
|
+
}
|
|
120
|
+
const formData = new FormData();
|
|
121
|
+
// Required fields
|
|
122
|
+
formData.append('state_center_id', this.cbpFinalObj?.ministry?.identifier || '');
|
|
123
|
+
formData.append('department_id', this.cbpFinalObj?.departments || '');
|
|
124
|
+
// Append multiple files with SAME key "files"
|
|
125
|
+
this.selectedFiles.forEach((file) => {
|
|
126
|
+
formData.append('files', file, file.name);
|
|
127
|
+
});
|
|
128
|
+
this.loading = true;
|
|
129
|
+
this.sharedService.uploadDocument(formData).subscribe({
|
|
130
|
+
next: (res) => {
|
|
131
|
+
this.loading = false;
|
|
132
|
+
this.uploadedFileData = res;
|
|
133
|
+
this.triggerFileSummary();
|
|
134
|
+
this.snackBar.open(res?.message, 'X', {
|
|
135
|
+
duration: 3000,
|
|
136
|
+
panelClass: ['snackbar-success']
|
|
137
|
+
});
|
|
138
|
+
},
|
|
139
|
+
error: (error) => {
|
|
140
|
+
this.loading = false;
|
|
141
|
+
this.snackBar.open(error?.error?.detail || 'Upload failed', 'X', { duration: 3000, panelClass: ['snackbar-error'] });
|
|
142
|
+
}
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
triggerFileSummary() {
|
|
146
|
+
if (!this.uploadedFileData?.successful_uploads?.length)
|
|
147
|
+
return;
|
|
148
|
+
const files = this.uploadedFileData.successful_uploads;
|
|
149
|
+
const totalFiles = files.length;
|
|
150
|
+
const dialogRefForProgress = this.dialog.open(ProgressDialogComponent, {
|
|
151
|
+
disableClose: true,
|
|
152
|
+
data: { progress: 0, message: `Processing 0 of ${totalFiles} summaries...` }
|
|
153
|
+
});
|
|
154
|
+
let completedFiles = 0;
|
|
155
|
+
const pollingRequests = files.map(file => interval(5000).pipe(startWith(0), // trigger immediately
|
|
156
|
+
switchMap(() => this.sharedService.triggerFileSummary(file.file_id)), // must return { summary_status }
|
|
157
|
+
tap((res) => {
|
|
158
|
+
if (res.summary_status === 'COMPLETED') {
|
|
159
|
+
completedFiles++;
|
|
160
|
+
dialogRefForProgress.componentInstance.data.progress = Math.floor((completedFiles / totalFiles) * 100);
|
|
161
|
+
dialogRefForProgress.componentInstance.data.message = `Processing ${completedFiles} of ${totalFiles} summaries...`;
|
|
162
|
+
}
|
|
163
|
+
}), takeWhile((res) => res.summary_status !== 'COMPLETED', true)));
|
|
164
|
+
forkJoin(pollingRequests).subscribe({
|
|
165
|
+
complete: () => {
|
|
166
|
+
dialogRefForProgress.componentInstance.data.progress = 100;
|
|
167
|
+
dialogRefForProgress.componentInstance.data.message = `All ${totalFiles} summaries completed!`;
|
|
168
|
+
setTimeout(() => {
|
|
169
|
+
dialogRefForProgress.close();
|
|
170
|
+
this.dialogRef.close('close');
|
|
171
|
+
}, 500);
|
|
172
|
+
},
|
|
173
|
+
error: () => {
|
|
174
|
+
dialogRefForProgress.close();
|
|
175
|
+
this.dialogRef.close('close');
|
|
176
|
+
}
|
|
177
|
+
});
|
|
178
|
+
}
|
|
179
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UploadDialogComponent, deps: [{ token: i1.MatDialogRef }, { token: i2.SharedService }, { token: i3.MatSnackBar }, { token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
180
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: UploadDialogComponent, selector: "app-upload-dialog", ngImport: i0, template: "<h2 mat-dialog-title>Upload Document</h2>\n\n<mat-dialog-content>\n\n <!-- <mat-form-field appearance=\"fill\" style=\"width: 100%; border: 1px solid #000;\">\n <input\n matInput\n [(ngModel)]=\"documentName\"\n placeholder=\"Document Name\"\n [disabled]=\"totalFileCount >= MAX_FILES\"\n >\n </mat-form-field> -->\n\n <!-- Upload Box -->\n <div\n class=\"file-upload-box\"\n style=\"margin-top: 30px;\"\n [class.disabled]=\"totalFileCount >= MAX_FILES\"\n (click)=\"totalFileCount < MAX_FILES && fileInput.click()\"\n >\n <input\n type=\"file\"\n #fileInput\n hidden\n multiple\n accept=\".pdf,.doc,.docx\"\n (change)=\"onFileSelected($event)\"\n >\n\n <p *ngIf=\"totalFileCount < MAX_FILES\">\n Click to select files\n </p>\n\n <p *ngIf=\"totalFileCount >= MAX_FILES\" class=\"error-text\">\n Maximum 10 documents allowed\n </p>\n\n <p><strong>Note:</strong> <small>PDF Files Only (Max:25 MB)</small></p>\n </div>\n\n <!-- Selected Files List -->\n <div *ngIf=\"selectedFiles.length > 0\" class=\"file-list\" style=\"margin-top:10px\">\n <p><strong>Selected Files</strong></p>\n\n <div class=\"file-item\" *ngFor=\"let file of selectedFiles; let i = index\">\n <span>{{ file.name }}</span>\n <span (click)=\"removeFile(i)\">\n <mat-icon class=\"file-cross-icon\" matTooltip=\"Remove\" matTooltipPosition=\"above\">close</mat-icon>\n </span>\n </div>\n </div>\n\n</mat-dialog-content>\n\n<div class=\"disclaimer-text\">\n <p>Disclaimer: Please do not upload any confidential documents.</p>\n</div>\n\n<mat-dialog-actions align=\"center\" style=\"margin: 20px 0;\">\n <button mat-button mat-dialog-close>Cancel</button>\n\n <button class=\"primary-btn cursor-pointer\"\n mat-raised-button\n color=\"primary\"\n (click)=\"upload()\"\n [disabled]=\"selectedFiles.length === 0\"\n >\n Upload\n </button>\n</mat-dialog-actions>\n\n<div class=\"overlay-loader\" *ngIf=\"loading\">\n <mat-spinner diameter=\"50\"></mat-spinner>\n</div>\n", styles: [".file-upload-box{border:2px dashed #ccc;padding:20px;text-align:center;cursor:pointer;margin-top:10px}.primary-btn{background-color:#1b4ca1;color:#fff}.disclaimer-text p{font-size:16px;font-family:Lato;font-weight:400;margin-left:24px}.file-cross-icon{height:24px;width:24px;vertical-align:middle;background:#d3d3d3;margin-left:10px;border-radius:25px}:host .mat-mdc-dialog-content{max-height:100vh!important}.cursor-pointer{cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.MatLegacyButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "component", type: i7.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "directive", type: i8.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] }); }
|
|
181
|
+
}
|
|
182
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UploadDialogComponent, decorators: [{
|
|
183
|
+
type: Component,
|
|
184
|
+
args: [{ selector: 'app-upload-dialog', template: "<h2 mat-dialog-title>Upload Document</h2>\n\n<mat-dialog-content>\n\n <!-- <mat-form-field appearance=\"fill\" style=\"width: 100%; border: 1px solid #000;\">\n <input\n matInput\n [(ngModel)]=\"documentName\"\n placeholder=\"Document Name\"\n [disabled]=\"totalFileCount >= MAX_FILES\"\n >\n </mat-form-field> -->\n\n <!-- Upload Box -->\n <div\n class=\"file-upload-box\"\n style=\"margin-top: 30px;\"\n [class.disabled]=\"totalFileCount >= MAX_FILES\"\n (click)=\"totalFileCount < MAX_FILES && fileInput.click()\"\n >\n <input\n type=\"file\"\n #fileInput\n hidden\n multiple\n accept=\".pdf,.doc,.docx\"\n (change)=\"onFileSelected($event)\"\n >\n\n <p *ngIf=\"totalFileCount < MAX_FILES\">\n Click to select files\n </p>\n\n <p *ngIf=\"totalFileCount >= MAX_FILES\" class=\"error-text\">\n Maximum 10 documents allowed\n </p>\n\n <p><strong>Note:</strong> <small>PDF Files Only (Max:25 MB)</small></p>\n </div>\n\n <!-- Selected Files List -->\n <div *ngIf=\"selectedFiles.length > 0\" class=\"file-list\" style=\"margin-top:10px\">\n <p><strong>Selected Files</strong></p>\n\n <div class=\"file-item\" *ngFor=\"let file of selectedFiles; let i = index\">\n <span>{{ file.name }}</span>\n <span (click)=\"removeFile(i)\">\n <mat-icon class=\"file-cross-icon\" matTooltip=\"Remove\" matTooltipPosition=\"above\">close</mat-icon>\n </span>\n </div>\n </div>\n\n</mat-dialog-content>\n\n<div class=\"disclaimer-text\">\n <p>Disclaimer: Please do not upload any confidential documents.</p>\n</div>\n\n<mat-dialog-actions align=\"center\" style=\"margin: 20px 0;\">\n <button mat-button mat-dialog-close>Cancel</button>\n\n <button class=\"primary-btn cursor-pointer\"\n mat-raised-button\n color=\"primary\"\n (click)=\"upload()\"\n [disabled]=\"selectedFiles.length === 0\"\n >\n Upload\n </button>\n</mat-dialog-actions>\n\n<div class=\"overlay-loader\" *ngIf=\"loading\">\n <mat-spinner diameter=\"50\"></mat-spinner>\n</div>\n", styles: [".file-upload-box{border:2px dashed #ccc;padding:20px;text-align:center;cursor:pointer;margin-top:10px}.primary-btn{background-color:#1b4ca1;color:#fff}.disclaimer-text p{font-size:16px;font-family:Lato;font-weight:400;margin-left:24px}.file-cross-icon{height:24px;width:24px;vertical-align:middle;background:#d3d3d3;margin-left:10px;border-radius:25px}:host .mat-mdc-dialog-content{max-height:100vh!important}.cursor-pointer{cursor:pointer}\n"] }]
|
|
185
|
+
}], ctorParameters: function () { return [{ type: i1.MatDialogRef }, { type: i2.SharedService }, { type: i3.MatSnackBar }, { type: i1.MatDialog }]; } });
|
|
186
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../library/sunbird-cb/cbp-ai/src/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.ts","../../../../../../../../library/sunbird-cb/cbp-ai/src/lib/modules/upload-document-page/upload-dialog/upload-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component } from '@angular/core';\nimport { MatDialogRef } from '@angular/material/dialog';\nimport { SharedService } from '../../shared/services/shared.service';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport { MatDialog } from '@angular/material/dialog';\nimport { ProgressDialogComponent } from '../progress-dialog/progress-dialog.component';\nimport { interval, forkJoin } from 'rxjs';\nimport { map, startWith, switchMap, takeWhile, tap } from 'rxjs/operators';\n@Component({\n  selector: 'app-upload-dialog',\n  templateUrl: './upload-dialog.component.html',\n  styleUrls: ['./upload-dialog.component.scss']\n})\nexport class UploadDialogComponent {\n\n  readonly MAX_FILES = 10;\n\n  documentName = '';\n  selectedFiles: File[] = [];\n  cbpFinalObj: any = {};\n  loading = false;\n  uploadedFileData: any = {};\n\n  constructor(\n    public dialogRef: MatDialogRef<UploadDialogComponent>,\n    public sharedService: SharedService,\n    public snackBar: MatSnackBar,\n    public dialog: MatDialog\n  ) {\n    this.cbpFinalObj = this.sharedService.getCBPPlanLocalStorage();\n  }\n\n  /** Already uploaded files count */\n  get uploadedCount(): number {\n    return this.cbpFinalObj?.documents?.length || 0;\n  }\n\n  /** Uploaded + newly selected */\n  get totalFileCount(): number {\n    return this.uploadedCount + this.selectedFiles.length;\n  }\n\n  onFileSelected(event: Event): void {\n    const input = event.target as HTMLInputElement;\n    if (!input.files) return;\n\n    const files = Array.from(input.files);\n    const allowedExtensions = ['pdf', 'doc', 'docx'];\n\n    for (const file of files) {\n      if (this.totalFileCount >= this.MAX_FILES) {\n        this.snackBar.open('You can upload a maximum of 10 documents.', 'X', {\n          duration: 3000,\n          panelClass: ['snackbar-error']\n        });\n        break;\n      }\n\n      const ext = file.name.split('.').pop()?.toLowerCase();\n      if (!ext || !allowedExtensions.includes(ext)) {\n        this.snackBar.open(\n          `Invalid file type: ${file.name}`,\n          'X',\n          { duration: 3000, panelClass: ['snackbar-error'] }\n        );\n        continue;\n      }\n\n      // Prevent duplicate selection\n      if (this.selectedFiles.some(f => f.name === file.name && f.size === file.size)) {\n        continue;\n      }\n\n      this.selectedFiles.push(file);\n    }\n\n    // Reset input so same file can be re-selected\n    input.value = '';\n  }\n\n  removeFile(index: number): void {\n    this.selectedFiles.splice(index, 1);\n  }\n\n  // upload(): void {\n  //   if (!this.documentName || this.selectedFiles.length === 0) {\n  //     return;\n  //   }\n\n  //   if (this.totalFileCount > this.MAX_FILES) {\n  //     this.snackBar.open('Maximum 10 documents allowed.', 'X', {\n  //       duration: 3000,\n  //       panelClass: ['snackbar-error']\n  //     });\n  //     return;\n  //   }\n\n  //   this.loading = true;\n\n  //   const uploadNext = (index: number) => {\n  //     if (index >= this.selectedFiles.length) {\n  //       this.loading = false;\n  //       this.dialogRef.close('close');\n  //       return;\n  //     }\n\n  //     const file = this.selectedFiles[index];\n\n  //     const reqBody = {\n  //       state_center_id: this.cbpFinalObj?.ministry?.identifier,\n  //       department_id: this.cbpFinalObj?.departments,\n  //       documentName: this.documentName\n  //     };\n\n  //     this.sharedService.uploadDocument(reqBody, file).subscribe({\n  //       next: (res) => {\n  //         this.uploadedFileData = res;\n  //         this.triggerFileSummary();\n  //         uploadNext(index + 1);\n  //       },\n  //       error: (err) => {\n  //         this.loading = false;\n  //         this.snackBar.open(\n  //           err?.error?.detail || 'Upload failed',\n  //           'X',\n  //           { duration: 3000, panelClass: ['snackbar-error'] }\n  //         );\n  //       }\n  //     });\n  //   };\n\n  //   uploadNext(0);\n  // }\n\n  upload(): void {\n    if (this.selectedFiles.length === 0) {\n      return;\n    }\n  \n    if (this.totalFileCount > this.MAX_FILES) {\n      this.snackBar.open('Maximum 10 documents allowed.', 'X', {\n        duration: 3000,\n        panelClass: ['snackbar-error']\n      });\n      return;\n    }\n  \n    const formData = new FormData();\n  \n    // Required fields\n    formData.append(\n      'state_center_id',\n      this.cbpFinalObj?.ministry?.identifier || ''\n    );\n  \n    formData.append(\n      'department_id',\n      this.cbpFinalObj?.departments || ''\n    );\n  \n    // Append multiple files with SAME key \"files\"\n    this.selectedFiles.forEach((file: File) => {\n      formData.append('files', file, file.name);\n    });\n  \n    this.loading = true;\n  \n    this.sharedService.uploadDocument(formData).subscribe({\n      next: (res) => {\n        this.loading = false;\n        this.uploadedFileData = res;\n        this.triggerFileSummary();\n        this.snackBar.open(res?.message, 'X', {\n          duration: 3000,\n          panelClass: ['snackbar-success']\n        });\n  \n        \n      },\n      error: (error) => {\n        this.loading = false;\n  \n        this.snackBar.open(\n          error?.error?.detail || 'Upload failed',\n          'X',\n          { duration: 3000, panelClass: ['snackbar-error'] }\n        );\n      }\n    });\n  }\n  \n\n\n  triggerFileSummary() {\n    if (!this.uploadedFileData?.successful_uploads?.length) return;\n  \n    const files = this.uploadedFileData.successful_uploads;\n    const totalFiles = files.length;\n  \n    const dialogRefForProgress = this.dialog.open(ProgressDialogComponent, {\n      disableClose: true,\n      data: { progress: 0, message: `Processing 0 of ${totalFiles} summaries...` }\n    });\n  \n    let completedFiles = 0;\n  \n    const pollingRequests = files.map(file =>\n      interval(5000).pipe(\n        startWith(0), // trigger immediately\n        switchMap(() => this.sharedService.triggerFileSummary(file.file_id)), // must return { summary_status }\n        tap((res: any) => {\n          if (res.summary_status === 'COMPLETED') {\n            completedFiles++;\n            dialogRefForProgress.componentInstance.data.progress = Math.floor((completedFiles / totalFiles) * 100);\n            dialogRefForProgress.componentInstance.data.message = `Processing ${completedFiles} of ${totalFiles} summaries...`;\n          }\n        }),\n        takeWhile((res: any) => res.summary_status !== 'COMPLETED', true)\n      )\n    );\n  \n    forkJoin(pollingRequests).subscribe({\n      complete: () => {\n        dialogRefForProgress.componentInstance.data.progress = 100;\n        dialogRefForProgress.componentInstance.data.message = `All ${totalFiles} summaries completed!`;\n        setTimeout(() => {\n          dialogRefForProgress.close();\n          this.dialogRef.close('close');\n        }, 500);\n      },\n      error: () => {\n        dialogRefForProgress.close();\n        this.dialogRef.close('close');\n      }\n    });\n  }\n  \n\n\n}\n","<h2 mat-dialog-title>Upload Document</h2>\n\n<mat-dialog-content>\n\n  <!-- <mat-form-field appearance=\"fill\" style=\"width: 100%; border: 1px solid #000;\">\n    <input\n      matInput\n      [(ngModel)]=\"documentName\"\n      placeholder=\"Document Name\"\n      [disabled]=\"totalFileCount >= MAX_FILES\"\n    >\n  </mat-form-field> -->\n\n  <!-- Upload Box -->\n  <div\n    class=\"file-upload-box\"\n    style=\"margin-top: 30px;\"\n    [class.disabled]=\"totalFileCount >= MAX_FILES\"\n    (click)=\"totalFileCount < MAX_FILES && fileInput.click()\"\n  >\n    <input\n      type=\"file\"\n      #fileInput\n      hidden\n      multiple\n      accept=\".pdf,.doc,.docx\"\n      (change)=\"onFileSelected($event)\"\n    >\n\n    <p *ngIf=\"totalFileCount < MAX_FILES\">\n      Click to select files\n    </p>\n\n    <p *ngIf=\"totalFileCount >= MAX_FILES\" class=\"error-text\">\n      Maximum 10 documents allowed\n    </p>\n\n    <p><strong>Note:</strong> <small>PDF Files Only (Max:25 MB)</small></p>\n  </div>\n\n  <!-- Selected Files List -->\n  <div *ngIf=\"selectedFiles.length > 0\" class=\"file-list\" style=\"margin-top:10px\">\n    <p><strong>Selected Files</strong></p>\n\n    <div class=\"file-item\" *ngFor=\"let file of selectedFiles; let i = index\">\n      <span>{{ file.name }}</span>\n      <span (click)=\"removeFile(i)\">\n        <mat-icon class=\"file-cross-icon\" matTooltip=\"Remove\" matTooltipPosition=\"above\">close</mat-icon>\n      </span>\n    </div>\n  </div>\n\n</mat-dialog-content>\n\n<div class=\"disclaimer-text\">\n  <p>Disclaimer: Please do not upload any confidential documents.</p>\n</div>\n\n<mat-dialog-actions align=\"center\" style=\"margin: 20px 0;\">\n  <button mat-button mat-dialog-close>Cancel</button>\n\n  <button class=\"primary-btn cursor-pointer\"\n    mat-raised-button\n    color=\"primary\"\n    (click)=\"upload()\"\n    [disabled]=\"selectedFiles.length === 0\"\n  >\n    Upload\n  </button>\n</mat-dialog-actions>\n\n<div class=\"overlay-loader\" *ngIf=\"loading\">\n  <mat-spinner diameter=\"50\"></mat-spinner>\n</div>\n"]}
|