bpm-core 0.0.101 → 0.0.103
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/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.mjs +26 -16
- package/esm2022/lib/components/shared-components/form-field/attachment-section/attachment-section.component.mjs +6 -6
- package/fesm2022/bpm-core.mjs +30 -19
- package/fesm2022/bpm-core.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -5,7 +5,6 @@ import { NgIf } from '@angular/common';
|
|
|
5
5
|
import { ControlValueAccessorDirective } from '../control-value-accessor.directive';
|
|
6
6
|
import { FormControl, NG_VALUE_ACCESSOR, ReactiveFormsModule, Validators, } from '@angular/forms';
|
|
7
7
|
import { DocsUploaderComponent } from '../doc-uploader/docs-uploader.component';
|
|
8
|
-
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
9
8
|
import { TranslatePipe } from "../../../../pipes/translate.pipe";
|
|
10
9
|
import * as i0 from "@angular/core";
|
|
11
10
|
import * as i1 from "../../../../services";
|
|
@@ -65,29 +64,40 @@ export class AttachmentSectionDataComponent extends ControlValueAccessorDirectiv
|
|
|
65
64
|
};
|
|
66
65
|
}
|
|
67
66
|
addAttachments() {
|
|
68
|
-
const
|
|
67
|
+
const newObj = {
|
|
69
68
|
fileDescription: this.formGroup.controls['description'].value,
|
|
70
69
|
attachmentcomment: this.formGroup.controls['comments'].value,
|
|
71
70
|
fileComments: this.formGroup.controls['comments'].value,
|
|
72
71
|
fileName: this.formGroup.controls['file'].value.fileName,
|
|
72
|
+
attachmentId: this.formGroup.controls['file'].value.attachmentId,
|
|
73
73
|
mimeType: this.formGroup.controls['file'].value.mimeType,
|
|
74
|
-
fileContents: this.formGroup.controls['file'].value.fileContents,
|
|
75
74
|
};
|
|
76
|
-
this.
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
75
|
+
this.dialogRef.close(newObj);
|
|
76
|
+
/* const data = {
|
|
77
|
+
fileDescription: this.formGroup.controls['description'].value,
|
|
78
|
+
attachmentcomment: this.formGroup.controls['comments'].value,
|
|
79
|
+
fileComments: this.formGroup.controls['comments'].value,
|
|
80
|
+
fileName: this.formGroup.controls['file'].value.fileName,
|
|
81
|
+
mimeType: this.formGroup.controls['file'].value.mimeType,
|
|
82
|
+
fileContents: this.formGroup.controls['file'].value.fileContents,
|
|
83
|
+
};
|
|
84
|
+
this.uploading = true;
|
|
85
|
+
this.coreService.getAttachments(data).pipe(
|
|
86
|
+
takeUntilDestroyed(this.destroyRef)
|
|
87
|
+
).subscribe((Response: any) => {
|
|
88
|
+
this.uploading = false;
|
|
89
|
+
if (Response) {
|
|
80
90
|
const newObj = {
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
91
|
+
fileDescription: this.formGroup.controls['description'].value,
|
|
92
|
+
attachmentcomment: this.formGroup.controls['comments'].value,
|
|
93
|
+
fileComments: this.formGroup.controls['comments'].value,
|
|
94
|
+
fileName: this.formGroup.controls['file'].value.fileName,
|
|
95
|
+
attachmentId: Response.attachment.attachmentId ?? this.formGroup.controls['file'].value.attachmentId,
|
|
96
|
+
mimeType: this.formGroup.controls['file'].value.mimeType,
|
|
87
97
|
};
|
|
88
98
|
this.dialogRef.close(newObj);
|
|
89
|
-
|
|
90
|
-
|
|
99
|
+
}
|
|
100
|
+
});*/
|
|
91
101
|
}
|
|
92
102
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AttachmentSectionDataComponent, deps: [{ token: i0.Injector }, { token: i1.CoreI18nService }, { token: i2.ToastrService }, { token: i1.CoreService }, { token: i3.DomSanitizer }, { token: i4.FormBuilder }, { token: i1.ActionStateService }, { token: i5.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
|
|
93
103
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: AttachmentSectionDataComponent, isStandalone: true, selector: "app-add-attachment-section", inputs: { hasColumnBreak: "hasColumnBreak", section: "section" }, providers: [
|
|
@@ -125,4 +135,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
125
135
|
}], section: [{
|
|
126
136
|
type: Input
|
|
127
137
|
}] } });
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-attachment-section.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  CUSTOM_ELEMENTS_SCHEMA,\r\n  DestroyRef,\r\n  forwardRef,\r\n  inject,\r\n  Inject,\r\n  Injector,\r\n  Input,\r\n} from '@angular/core';\r\nimport { TextareaComponent } from '../textarea/textarea.component';\r\nimport {\r\n  MAT_DIALOG_DATA,\r\n  MatDialogActions,\r\n  MatDialogClose,\r\n  MatDialogContent,\r\n  MatDialogModule,\r\n  MatDialogRef,\r\n} from '@angular/material/dialog';\r\nimport { NgIf } from '@angular/common';\r\nimport { ControlValueAccessorDirective } from '../control-value-accessor.directive';\r\nimport { Section } from '../../../../interfaces';\r\nimport {\r\n  FormBuilder,\r\n  FormControl,\r\n  FormGroup,\r\n  NG_VALUE_ACCESSOR,\r\n  ReactiveFormsModule,\r\n  Validators,\r\n} from '@angular/forms';\r\nimport { DocsUploaderComponent } from '../doc-uploader/docs-uploader.component';\r\nimport { ToastrService } from 'ngx-toastr';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport {ActionStateService, CoreI18nService, CoreService} from \"../../../../services\";\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport {TranslatePipe} from \"../../../../pipes/translate.pipe\";\r\n\r\n@Component({\r\n  selector: 'app-add-attachment-section',\r\n  templateUrl: './add-attachment-section.component.html',\r\n  styleUrls: ['./add-attachment-section.component.scss'],\r\n  standalone: true,\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  imports: [\r\n    TextareaComponent,\r\n    MatDialogContent,\r\n    DocsUploaderComponent,\r\n    MatDialogActions,\r\n    NgIf,\r\n    MatDialogModule,\r\n    ReactiveFormsModule,\r\n    MatDialogClose,\r\n    TranslatePipe\r\n  ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => AttachmentSectionDataComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class AttachmentSectionDataComponent<\r\n  Type\r\n> extends ControlValueAccessorDirective<Type> {\r\n  popupData: any = {};\r\n  popupDataOrg: any = {};\r\n  uploading: boolean;\r\n  editMode: boolean;\r\n  @Input() hasColumnBreak: boolean;\r\n  @Input() section: Section;\r\n  formGroup: FormGroup;\r\n  destroyRef = inject(DestroyRef);\r\n\r\n\r\n  constructor(\r\n    injector: Injector,\r\n    i18n: CoreI18nService,\r\n    toasterService: ToastrService,\r\n    coreService: CoreService,\r\n    sanitizer: DomSanitizer,\r\n    fb: FormBuilder,\r\n    actionStateService: ActionStateService,\r\n    public dialogRef: MatDialogRef<any>,\r\n    @Inject(MAT_DIALOG_DATA) public dialogData: any\r\n  ) {\r\n    super(injector, i18n, toasterService, coreService, sanitizer, fb, actionStateService);\r\n  }\r\n\r\n  override ngOnInit() {\r\n    // super.ngOnInit()\r\n    this.createForm();\r\n    if (this.dialogData?.attachmentListData) {\r\n      this.popupData = this.dialogData.attachmentListData;\r\n      this.popupDataOrg = Object.assign({}, this.popupData);\r\n      this.formGroup.controls['file'].setValue(\r\n        this.dialogData.attachmentListData\r\n      );\r\n      this.formGroup.controls['description'].setValue(\r\n        this.dialogData.attachmentListData.fileDescription\r\n      );\r\n      this.formGroup.controls['comments'].setValue(\r\n        this.dialogData.attachmentListData.fileComments\r\n      );\r\n      this.editMode = true;\r\n    }\r\n  }\r\n  createForm() {\r\n    this.formGroup = this.fb.group({\r\n      file: new FormControl(null, Validators.required),\r\n      description: new FormControl(null,this.dialogData.descriptionRequired ? Validators.required: null),\r\n      comments: new FormControl(null, this.dialogData.commentsRequired ? Validators.required: null),\r\n    });\r\n  }\r\n\r\n  close() {\r\n    this.dialogRef.close(this.popupDataOrg);\r\n  }\r\n\r\n  handleEmitValue(data: any, fieldName: string) {\r\n    this.popupData[fieldName] = data;\r\n  }\r\n\r\n  handleAttachmentEmitValue(data: any) {\r\n    this.popupData = {\r\n      fileContents: data?.fileContents,\r\n      fileName: data?.fileName,\r\n      mimeType: data?.mimeType,\r\n      fileDescription: this.popupData?.fileDescription,\r\n      attachmentcomment: this.popupData?.attachmentcomment,\r\n      fileComments: this.popupData?.attachmentcomment,\r\n    };\r\n  }\r\n\r\n  addAttachments() {\r\n    const data = {\r\n      fileDescription: this.formGroup.controls['description'].value,\r\n      attachmentcomment: this.formGroup.controls['comments'].value,\r\n      fileComments: this.formGroup.controls['comments'].value,\r\n      fileName: this.formGroup.controls['file'].value.fileName,\r\n      mimeType: this.formGroup.controls['file'].value.mimeType,\r\n      fileContents: this.formGroup.controls['file'].value.fileContents,\r\n    };\r\n    this.uploading = true;\r\n    this.coreService.getAttachments(data).pipe(\r\n      takeUntilDestroyed(this.destroyRef)\r\n    ).subscribe((Response: any) => {\r\n      this.uploading = false;\r\n      if (Response) {\r\n        const newObj = {\r\n          fileDescription: this.formGroup.controls['description'].value,\r\n          attachmentcomment: this.formGroup.controls['comments'].value,\r\n          fileComments: this.formGroup.controls['comments'].value,\r\n          fileName: this.formGroup.controls['file'].value.fileName,\r\n          attachmentId: Response.attachment.attachmentId ?? this.formGroup.controls['file'].value.attachmentId,\r\n          mimeType: this.formGroup.controls['file'].value.mimeType,\r\n        };\r\n        this.dialogRef.close(newObj);\r\n      }\r\n    });\r\n  }\r\n}\r\n","<div class=\"popup-container\">\r\n  <div class=\"d-flex align-items-center justify-content-end\" mat-dialog-title>\r\n    <h3 class=\"mb-0 font-16 fw-medium\">{{ 'addAttachments' | translate }}</h3>\r\n    <ds-button icon matDialogClose>\r\n      <ds-icon icon=\"close\" class=\"fs-20 fc-black\"></ds-icon>\r\n    </ds-button>\r\n  </div>\r\n  <mat-dialog-content>\r\n    <div class=\"px-md-4 mt-3\">\r\n      <form [formGroup]=\"formGroup\">\r\n        <app-file-uploader\r\n          class=\"section-item full\" [field]=\"popupData\" name=\"file\" [attachments]=\"dialogData?.attachments\"\r\n          [labelTextReadMode]=\"'Attachment' | translate\" [labelTextWriteMode]=\"'Attachment' | translate\"\r\n          [hasColumnBreak]=\"false\" [label]=\"'Attachment' | translate\" [required]=\"true\" [multiple]=\"false\"\r\n          [allowedExtensions]=\"dialogData?.data\"\r\n          [allAttachments]=\"dialogData?.attachments\"\r\n          [isReadOnly]=\"section?.header?.readOnly\" [showActions]=\"false\"\r\n          formControlName=\"file\">\r\n        </app-file-uploader>\r\n\r\n        <app-textarea\r\n          class=\"section-item d-block mt-4 mb-4\" [section]=\"section\" [field]=\"popupData?.fileDescription\" name=\"fileDescription\"\r\n          [labelTextReadMode]=\"'description' | translate\" [labelTextWriteMode]=\"'description' | translate\"\r\n          [hasColumnBreak]=\"false\" (emitedValue)=\"handleEmitValue($event,'fileDescription')\"\r\n          [label]=\"'description' | translate\" [required]=\"dialogData?.isRequired\" [minLength]=\"1\" [maxLength]=\"500\"\r\n          [isReadOnly]=\"section?.header?.readOnly\" [errorMessage]=\"'lenghtMin1Max500' | translate\"\r\n          formControlName=\"description\">\r\n        </app-textarea>\r\n\r\n        <app-textarea\r\n          class=\"section-item\" [section]=\"section\" [field]=\"popupData?.attachmentcomment\" name=\"attachmentcomment\"\r\n          [labelTextReadMode]=\"'comments' | translate\" [labelTextWriteMode]=\"'comments' | translate\"\r\n          [hasColumnBreak]=\"false\" (emitedValue)=\"handleEmitValue($event,'attachmentcomment')\"\r\n          [label]=\"'comments' | translate\" [required]=\"false\" [minLength]=\"1\" [maxLength]=\"500\"\r\n          [isReadOnly]=\"section?.header?.readOnly\" [errorMessage]=\"'lenghtMin1Max500' | translate\"\r\n          formControlName=\"comments\">\r\n        </app-textarea>\r\n      </form>\r\n    </div>\r\n  </mat-dialog-content>\r\n  <mat-dialog-actions class=\"default-footer justify-content-end gap-3\">\r\n    <ds-button shape=\"outline\" matDialogClose [disabled]=\"uploading\" [class.disabled]=\"uploading\">{{ 'cancel' | translate }}</ds-button>\r\n    <ds-button\r\n      (click)=\"addAttachments()\" [loading]=\"uploading\"\r\n      [disabled]=\"(!formGroup?.value?.file?.attachmentId || (dialogData?.isRequired && !formGroup?.value?.description) || uploading || !formGroup.valid)\">\r\n      <ng-container *ngIf=\"!editMode; else editTemplate\">\r\n        <span>{{ 'add' | translate }}</span>\r\n      </ng-container>\r\n      <ng-template #editTemplate>\r\n        <span>{{ 'edit' | translate }}</span>\r\n      </ng-template>\r\n    </ds-button>\r\n  </mat-dialog-actions>\r\n</div>\r\n"]}
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-attachment-section.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/add-attachment-section/add-attachment-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, forwardRef, inject, Inject, Injector, Input,} from '@angular/core';\r\nimport {TextareaComponent} from '../textarea/textarea.component';\r\nimport {MAT_DIALOG_DATA, MatDialogActions, MatDialogClose, MatDialogContent, MatDialogModule, MatDialogRef,} from '@angular/material/dialog';\r\nimport {NgIf} from '@angular/common';\r\nimport {ControlValueAccessorDirective} from '../control-value-accessor.directive';\r\nimport {Section} from '../../../../interfaces';\r\nimport {FormBuilder, FormControl, FormGroup, NG_VALUE_ACCESSOR, ReactiveFormsModule, Validators,} from '@angular/forms';\r\nimport {DocsUploaderComponent} from '../doc-uploader/docs-uploader.component';\r\nimport {ToastrService} from 'ngx-toastr';\r\nimport {DomSanitizer} from '@angular/platform-browser';\r\nimport {ActionStateService, CoreI18nService, CoreService} from \"../../../../services\";\r\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\r\nimport {TranslatePipe} from \"../../../../pipes/translate.pipe\";\r\n\r\n@Component({\r\n  selector: 'app-add-attachment-section',\r\n  templateUrl: './add-attachment-section.component.html',\r\n  styleUrls: ['./add-attachment-section.component.scss'],\r\n  standalone: true,\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  imports: [\r\n    TextareaComponent,\r\n    MatDialogContent,\r\n    DocsUploaderComponent,\r\n    MatDialogActions,\r\n    NgIf,\r\n    MatDialogModule,\r\n    ReactiveFormsModule,\r\n    MatDialogClose,\r\n    TranslatePipe\r\n  ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => AttachmentSectionDataComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class AttachmentSectionDataComponent<\r\n  Type\r\n> extends ControlValueAccessorDirective<Type> {\r\n  popupData: any = {};\r\n  popupDataOrg: any = {};\r\n  uploading: boolean;\r\n  editMode: boolean;\r\n  @Input() hasColumnBreak: boolean;\r\n  @Input() section: Section;\r\n  formGroup: FormGroup;\r\n  destroyRef = inject(DestroyRef);\r\n\r\n\r\n  constructor(\r\n    injector: Injector,\r\n    i18n: CoreI18nService,\r\n    toasterService: ToastrService,\r\n    coreService: CoreService,\r\n    sanitizer: DomSanitizer,\r\n    fb: FormBuilder,\r\n    actionStateService: ActionStateService,\r\n    public dialogRef: MatDialogRef<any>,\r\n    @Inject(MAT_DIALOG_DATA) public dialogData: any\r\n  ) {\r\n    super(injector, i18n, toasterService, coreService, sanitizer, fb, actionStateService);\r\n  }\r\n\r\n  override ngOnInit() {\r\n    // super.ngOnInit()\r\n    this.createForm();\r\n    if (this.dialogData?.attachmentListData) {\r\n      this.popupData = this.dialogData.attachmentListData;\r\n      this.popupDataOrg = Object.assign({}, this.popupData);\r\n      this.formGroup.controls['file'].setValue(\r\n        this.dialogData.attachmentListData\r\n      );\r\n      this.formGroup.controls['description'].setValue(\r\n        this.dialogData.attachmentListData.fileDescription\r\n      );\r\n      this.formGroup.controls['comments'].setValue(\r\n        this.dialogData.attachmentListData.fileComments\r\n      );\r\n      this.editMode = true;\r\n    }\r\n  }\r\n  createForm() {\r\n    this.formGroup = this.fb.group({\r\n      file: new FormControl(null, Validators.required),\r\n      description: new FormControl(null,this.dialogData.descriptionRequired ? Validators.required: null),\r\n      comments: new FormControl(null, this.dialogData.commentsRequired ? Validators.required: null),\r\n    });\r\n  }\r\n\r\n  close() {\r\n    this.dialogRef.close(this.popupDataOrg);\r\n  }\r\n\r\n  handleEmitValue(data: any, fieldName: string) {\r\n    this.popupData[fieldName] = data;\r\n  }\r\n\r\n  handleAttachmentEmitValue(data: any) {\r\n    this.popupData = {\r\n      fileContents: data?.fileContents,\r\n      fileName: data?.fileName,\r\n      mimeType: data?.mimeType,\r\n      fileDescription: this.popupData?.fileDescription,\r\n      attachmentcomment: this.popupData?.attachmentcomment,\r\n      fileComments: this.popupData?.attachmentcomment,\r\n    };\r\n  }\r\n\r\n  addAttachments() {\r\n    const newObj = {\r\n      fileDescription: this.formGroup.controls['description'].value,\r\n      attachmentcomment: this.formGroup.controls['comments'].value,\r\n      fileComments: this.formGroup.controls['comments'].value,\r\n      fileName: this.formGroup.controls['file'].value.fileName,\r\n      attachmentId: this.formGroup.controls['file'].value.attachmentId,\r\n      mimeType: this.formGroup.controls['file'].value.mimeType,\r\n    };\r\n    this.dialogRef.close(newObj);\r\n\r\n/*    const data = {\r\n      fileDescription: this.formGroup.controls['description'].value,\r\n      attachmentcomment: this.formGroup.controls['comments'].value,\r\n      fileComments: this.formGroup.controls['comments'].value,\r\n      fileName: this.formGroup.controls['file'].value.fileName,\r\n      mimeType: this.formGroup.controls['file'].value.mimeType,\r\n      fileContents: this.formGroup.controls['file'].value.fileContents,\r\n    };\r\n    this.uploading = true;\r\n    this.coreService.getAttachments(data).pipe(\r\n      takeUntilDestroyed(this.destroyRef)\r\n    ).subscribe((Response: any) => {\r\n      this.uploading = false;\r\n      if (Response) {\r\n        const newObj = {\r\n          fileDescription: this.formGroup.controls['description'].value,\r\n          attachmentcomment: this.formGroup.controls['comments'].value,\r\n          fileComments: this.formGroup.controls['comments'].value,\r\n          fileName: this.formGroup.controls['file'].value.fileName,\r\n          attachmentId: Response.attachment.attachmentId ?? this.formGroup.controls['file'].value.attachmentId,\r\n          mimeType: this.formGroup.controls['file'].value.mimeType,\r\n        };\r\n        this.dialogRef.close(newObj);\r\n      }\r\n    });*/\r\n  }\r\n}\r\n","<div class=\"popup-container\">\r\n  <div class=\"d-flex align-items-center justify-content-end\" mat-dialog-title>\r\n    <h3 class=\"mb-0 font-16 fw-medium\">{{ 'addAttachments' | translate }}</h3>\r\n    <ds-button icon matDialogClose>\r\n      <ds-icon icon=\"close\" class=\"fs-20 fc-black\"></ds-icon>\r\n    </ds-button>\r\n  </div>\r\n  <mat-dialog-content>\r\n    <div class=\"px-md-4 mt-3\">\r\n      <form [formGroup]=\"formGroup\">\r\n        <app-file-uploader\r\n          class=\"section-item full\" [field]=\"popupData\" name=\"file\" [attachments]=\"dialogData?.attachments\"\r\n          [labelTextReadMode]=\"'Attachment' | translate\" [labelTextWriteMode]=\"'Attachment' | translate\"\r\n          [hasColumnBreak]=\"false\" [label]=\"'Attachment' | translate\" [required]=\"true\" [multiple]=\"false\"\r\n          [allowedExtensions]=\"dialogData?.data\"\r\n          [allAttachments]=\"dialogData?.attachments\"\r\n          [isReadOnly]=\"section?.header?.readOnly\" [showActions]=\"false\"\r\n          formControlName=\"file\">\r\n        </app-file-uploader>\r\n\r\n        <app-textarea\r\n          class=\"section-item d-block mt-4 mb-4\" [section]=\"section\" [field]=\"popupData?.fileDescription\" name=\"fileDescription\"\r\n          [labelTextReadMode]=\"'description' | translate\" [labelTextWriteMode]=\"'description' | translate\"\r\n          [hasColumnBreak]=\"false\" (emitedValue)=\"handleEmitValue($event,'fileDescription')\"\r\n          [label]=\"'description' | translate\" [required]=\"dialogData?.isRequired\" [minLength]=\"1\" [maxLength]=\"500\"\r\n          [isReadOnly]=\"section?.header?.readOnly\" [errorMessage]=\"'lenghtMin1Max500' | translate\"\r\n          formControlName=\"description\">\r\n        </app-textarea>\r\n\r\n        <app-textarea\r\n          class=\"section-item\" [section]=\"section\" [field]=\"popupData?.attachmentcomment\" name=\"attachmentcomment\"\r\n          [labelTextReadMode]=\"'comments' | translate\" [labelTextWriteMode]=\"'comments' | translate\"\r\n          [hasColumnBreak]=\"false\" (emitedValue)=\"handleEmitValue($event,'attachmentcomment')\"\r\n          [label]=\"'comments' | translate\" [required]=\"false\" [minLength]=\"1\" [maxLength]=\"500\"\r\n          [isReadOnly]=\"section?.header?.readOnly\" [errorMessage]=\"'lenghtMin1Max500' | translate\"\r\n          formControlName=\"comments\">\r\n        </app-textarea>\r\n      </form>\r\n    </div>\r\n  </mat-dialog-content>\r\n  <mat-dialog-actions class=\"default-footer justify-content-end gap-3\">\r\n    <ds-button shape=\"outline\" matDialogClose [disabled]=\"uploading\" [class.disabled]=\"uploading\">{{ 'cancel' | translate }}</ds-button>\r\n    <ds-button\r\n      (click)=\"addAttachments()\" [loading]=\"uploading\"\r\n      [disabled]=\"(!formGroup?.value?.file?.attachmentId || (dialogData?.isRequired && !formGroup?.value?.description) || uploading || !formGroup.valid)\">\r\n      <ng-container *ngIf=\"!editMode; else editTemplate\">\r\n        <span>{{ 'add' | translate }}</span>\r\n      </ng-container>\r\n      <ng-template #editTemplate>\r\n        <span>{{ 'edit' | translate }}</span>\r\n      </ng-template>\r\n    </ds-button>\r\n  </mat-dialog-actions>\r\n</div>\r\n"]}
|
|
@@ -42,11 +42,11 @@ export class AttachmentSectionComponent extends ControlValueAccessorDirective {
|
|
|
42
42
|
if (this.control.value) {
|
|
43
43
|
this.attachments = this.control.value;
|
|
44
44
|
}
|
|
45
|
-
if (this.attachments) {
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
}
|
|
45
|
+
/*if (this.attachments) {
|
|
46
|
+
this.attachments.forEach(element => {
|
|
47
|
+
element.name = element.fileName;
|
|
48
|
+
});
|
|
49
|
+
}*/
|
|
50
50
|
this.actionStateService.resetAction$
|
|
51
51
|
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
52
52
|
.subscribe(res => {
|
|
@@ -231,4 +231,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
231
231
|
type: ViewChild,
|
|
232
232
|
args: ['paginator']
|
|
233
233
|
}] } });
|
|
234
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment-section.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/attachment-section/attachment-section.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/attachment-section/attachment-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, EventEmitter, forwardRef, inject, Input, OnDestroy, Output, ViewChild} from '@angular/core';\r\nimport {AttachmentSectionDataComponent} from '../add-attachment-section/add-attachment-section.component';\r\nimport {CdkDrag, CdkDragDrop, CdkDropList, moveItemInArray} from '@angular/cdk/drag-drop';\r\nimport {SatPopoverModule} from '@ncstate/sat-popover';\r\nimport {MatTooltip} from \"@angular/material/tooltip\";\r\nimport {NgClass, NgForOf, NgIf, SlicePipe} from \"@angular/common\";\r\nimport {DocsUploaderComponent} from '../doc-uploader/docs-uploader.component';\r\nimport {DeleteDialogComponent} from \"../../dialogs/delete-dialog/delete-dialog.component\";\r\nimport {ControlValueAccessorDirective} from \"../control-value-accessor.directive\";\r\nimport {MatDialog} from \"@angular/material/dialog\";\r\nimport {NG_VALUE_ACCESSOR} from '@angular/forms';\r\nimport {MatPaginator} from \"@angular/material/paginator\";\r\nimport {\r\n  MatCell,\r\n  MatCellDef,\r\n  MatColumnDef,\r\n  MatHeaderCell,\r\n  MatHeaderCellDef,\r\n  MatHeaderRow,\r\n  MatHeaderRowDef,\r\n  MatRow,\r\n  MatRowDef,\r\n  MatTable,\r\n  MatTableDataSource\r\n} from \"@angular/material/table\";\r\nimport { FormLabelComponent } from '../form-label/form-label.component';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport {TranslatePipe} from \"../../../../pipes/translate.pipe\";\r\n\r\n\r\n@Component({\r\n  selector: 'app-attachment-section',\r\n  templateUrl: './attachment-section.component.html',\r\n  styleUrls: ['./attachment-section.component.scss'],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => AttachmentSectionComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n  imports: [\r\n    SatPopoverModule,\r\n    MatTooltip,\r\n    NgClass,\r\n    CdkDropList,\r\n    DocsUploaderComponent,\r\n    CdkDrag,\r\n    SlicePipe,\r\n    MatPaginator,\r\n    MatTable,\r\n    MatColumnDef,\r\n    MatCell,\r\n    MatCellDef,\r\n    MatHeaderCellDef,\r\n    MatHeaderCell,\r\n    MatRow,\r\n    MatHeaderRow,\r\n    MatHeaderRowDef,\r\n    MatRowDef,\r\n    FormLabelComponent,\r\n    TranslatePipe\r\n  ],\r\n  standalone: true\r\n})\r\nexport class AttachmentSectionComponent extends ControlValueAccessorDirective<any> implements AfterViewInit {\r\n  @Input() className = 'info-section';\r\n  @Output() downloadActionClicked = new EventEmitter();\r\n  @Input() customDownload: boolean;\r\n\r\n  @Input() attachmentsMax = 1000;\r\n  @Input() isSortable = false;\r\n  @Input() downloadAll = false;\r\n  popupData: any = {};\r\n  @Input() isRequired: boolean = false;\r\n  @Input() descriptionRequired: boolean;\r\n  @Input() commentsRequired: boolean;\r\n  @Input() allowedExtensions = '';\r\n  @Output() emitedValue = new EventEmitter();\r\n  dialog = inject(MatDialog);\r\n  displayedColumns: string[] = [\"index\", \"file\", \"description\", \"comment\", \"actions\"];\r\n  dataSource: MatTableDataSource<any>;\r\n  @ViewChild('paginator') paginator: MatPaginator;\r\n  totalRecords: number = 0;\r\n  pageSize: number = 5;\r\n  pageNumber: number = 0;\r\n  destroyRef = inject(DestroyRef);\r\n\r\n  override ngOnInit(): void {\r\n    super.ngOnInit()\r\n    if (this.control.value) {\r\n      this.attachments = this.control.value\r\n    }\r\n    if (this.attachments) {\r\n      this.attachments.forEach(element => {\r\n        element.name = element.fileName;\r\n      });\r\n    }\r\n    this.actionStateService.resetAction$\r\n    .pipe(takeUntilDestroyed(this.destroyRef))\r\n    .subscribe(res => {\r\n      if (!this.isReadOnly && this.control.enabled) {\r\n        this.control.reset();\r\n      }\r\n    });\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.addDataToTable();\r\n    this.paginator._intl.itemsPerPageLabel = this.i18n.translate('itemsPerPage')\r\n  }\r\n\r\n  onPaginateChange(event: any) {\r\n    this.pageNumber = event.pageIndex\r\n  }\r\n\r\n  drop(event: CdkDragDrop<string[]>) {\r\n    moveItemInArray(this.attachments, event.previousIndex, event.currentIndex);\r\n  }\r\n\r\n\r\n  resetAttachmentData() {\r\n    if (!this.isReadOnly) {\r\n      this.attachments = [];\r\n      this.emitedValue.emit(this.attachments);\r\n    }\r\n  }\r\n\r\n  addDataToTable(){\r\n    this.dataSource = new MatTableDataSource(this.attachments);\r\n    this.totalRecords = this.dataSource.data.length;\r\n    this.dataSource.paginator = this.paginator;\r\n  }\r\n\r\n  handleEmitValue(data: any, fieldName: string) {\r\n    this.popupData[fieldName] = data;\r\n  }\r\n\r\n  addAttachment(): void {\r\n    const dialogRef = this.dialog.open(AttachmentSectionDataComponent, {\r\n      panelClass: ['main-popup', 'add-attachment-dialog'],\r\n      data: {\r\n        attachmentListData: null,\r\n        data: this.allowedExtensions,\r\n        isRequired: this.isRequired,\r\n        multiple: this.multiple,\r\n        attachments: this.attachments,\r\n        descriptionRequired: this.descriptionRequired,\r\n        commentsRequired: this.commentsRequired\r\n      }\r\n    });\r\n    dialogRef.afterClosed().subscribe((resultData) => {\r\n      if (resultData != 'close') {\r\n        if (resultData?.attachmentId) {\r\n          this.attachments.push(resultData);\r\n    this.addDataToTable();\r\n\r\n        }\r\n      }\r\n      this.control.setValue(this.attachments)\r\n    });\r\n  }\r\n\r\n  deleteAttachments(index: number, item: any) {\r\n    const dialogRef = this.dialog.open(DeleteDialogComponent, {\r\n      panelClass: ['main-popup', 'add-attachment-dialog']\r\n    });\r\n    dialogRef.afterClosed().subscribe((resultData) => {\r\n      if (resultData == 'yes') {\r\n        this.deleteAttachment(index, item);\r\n      }\r\n    });\r\n  }\r\n\r\n  deleteAttachment(index: number, item: any) {\r\n    this.attachments = this.attachments.filter((row: any) => {\r\n      return row.attachmentId != item.attachmentId;\r\n    });\r\n    this.addDataToTable();\r\n    this.control.setValue(this.attachments)\r\n  }\r\n\r\n  editRow(rowData, index): void {\r\n    const dialogRef = this.dialog.open(AttachmentSectionDataComponent, {\r\n      panelClass: ['main-popup', 'add-attachment-dialog'],\r\n      data: {\r\n        attachmentListData: Object.assign(rowData),\r\n        data: this.allowedExtensions,\r\n        isRequired: this.isRequired,\r\n        multiple: this.multiple,\r\n        attachments: this.attachments,\r\n\r\n      }\r\n    });\r\n    dialogRef.afterClosed().subscribe((resultData) => {\r\n      if (resultData != 'close') {\r\n        if (resultData?.attachmentId) {\r\n          this.attachments[index] = resultData;\r\n          this.emitedValue.emit(this.attachments);\r\n          this.addDataToTable();\r\n          this.control.setValue(this.attachments)\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  downloadAllAttachments(event) {\r\n    this.loading = true\r\n    const downloads = this.attachments.map((file) => this.downloadFile(event, file));\r\n    Promise.all(downloads)\r\n      .then(() => {\r\n        this.loading = false\r\n      })\r\n      .catch((error) => {\r\n        this.loading = false\r\n      });\r\n  }\r\n\r\n  downloadFile(event, field): Promise<void> {\r\n    return new Promise((resolve, reject) => {\r\n      this.coreService.loadFile(field.attachmentId).pipe(\r\n        takeUntilDestroyed(this.destroyRef)\r\n      ).subscribe(\r\n        (responseObject: { body: any; }) => {\r\n          const fileInformation = responseObject.body;\r\n          this.coreService.saveFile(fileInformation)\r\n          resolve();\r\n        },\r\n        error => {\r\n          this.toasterService.error(error.error?.['message']);\r\n        }\r\n      );\r\n    });\r\n  }\r\n\r\n  customDownloadAction(event){\r\n    this.downloadActionClicked.emit(event);\r\n  }\r\n\r\n}\r\n","<div class=\"mt-2 p-0\">\r\n  @if(label){\r\n    <app-form-label [label]=\"label\" [optional]=\"(required || mandatory ? false : true) && !isReadOnly\" [tooltip]=\"tooltip\"></app-form-label>\r\n  }\r\n\r\n  @if (!attachments?.length && !isReadOnly) {\r\n    <section\r\n      [ngClass]=\"insideTable ? 'file-uploader-table' : 'file-uploader'\"\r\n      class=\"mb-2\"\r\n      [class.insideTableStyle]=\"insideTable\"\r\n      (click)=\"addAttachment()\">\r\n      <div\r\n        [ngClass]=\"insideTable ? 'file-uploader-table-dev' : ''\"\r\n        class=\"file-uploader-input\">\r\n        <div class=\"icon mb-1\">\r\n          <svg\r\n            [ngClass]=\"insideTable ? 'file-uploader-table-svg' : ''\"\r\n            width=\"41\"\r\n            height=\"38\"\r\n            viewBox=\"0 0 41 38\"\r\n            fill=\"none\"\r\n            xmlns=\"http://www.w3.org/2000/svg\">\r\n            <path\r\n              d=\"M0 22.1947V20.6736C0.0971303 20.1019 0.070094 19.5141 0.276371 18.9533C1.28372 16.2086 3.21231 14.5023 6.0421 13.8094C6.70499 13.6472 6.68497 13.6632 6.69899 12.9843C6.73203 11.3321 6.99839 9.71992 7.62423 8.17986C8.86289 5.13678 10.9467 2.83969 13.8816 1.39175C17.168 -0.230424 20.5956 -0.450719 24.0553 0.81598C27.4929 2.07467 29.9622 4.41581 31.4802 7.74828C31.7786 8.40316 32.027 9.08307 32.1712 9.79202C32.2402 10.1315 32.4035 10.2566 32.7529 10.3107C36.7012 10.9165 39.3358 13.1255 40.6946 16.8735C40.9069 17.4603 40.9199 18.0731 40.9599 18.6829C40.9649 18.7601 40.9389 18.8442 41 18.9113V20.5124C40.9109 20.995 40.969 21.4937 40.8608 21.9734C40.5244 23.4614 39.8454 24.7821 38.8501 25.9297C37.4522 27.5418 35.7059 28.5882 33.6161 29.0519C32.791 29.2351 31.9499 29.2521 31.1117 29.2922C30.6571 29.3142 30.584 29.193 30.592 28.7484C30.6451 25.8446 29.802 23.2571 27.8624 21.0591C25.9979 18.9463 23.6597 17.7167 20.867 17.4012C18.8553 17.1739 16.9057 17.4593 15.0612 18.3395C11.8319 19.8816 9.81416 22.4069 8.96102 25.8696C8.74273 26.7538 8.68265 27.658 8.70568 28.5702C8.7217 29.2111 8.60254 29.3122 7.95968 29.2972C5.95098 29.2511 4.10551 28.7234 2.58146 27.3596C1.07644 26.0168 0.0680913 24.3996 0.0400537 22.3028C0.0400537 22.2607 0.0250336 22.2257 0 22.1937V22.1947Z\"\r\n              fill=\"#DEE0E2\"/>\r\n            <path\r\n              d=\"M29.0303 28.2632C29.0604 33.4031 24.8657 37.6187 19.6838 37.6548C14.5169 37.6908 10.2852 33.4952 10.2521 28.3042C10.2201 23.1403 14.4297 18.9126 19.6227 18.8946C24.8037 18.8766 28.9993 23.0542 29.0303 28.2632Z\"\r\n              fill=\"#8E9AA0\"/>\r\n            <path\r\n              d=\"M20.5573 25.2644C20.4622 25.4477 20.5012 25.5939 20.5012 25.734C20.4982 28.2154 20.5002 30.6957 20.4982 33.177C20.4982 33.8099 20.2339 34.1704 19.7462 34.2234C19.2645 34.2765 18.88 33.9831 18.8169 33.5025C18.7959 33.3443 18.7969 33.183 18.7969 33.0238C18.7959 30.5826 18.7969 28.1423 18.7969 25.701C18.7969 25.5728 18.7969 25.4447 18.7969 25.2003C18.1971 25.8031 17.6774 26.3288 17.1527 26.8505C17.0115 26.9907 16.8683 27.1349 16.7061 27.2471C16.3566 27.4864 15.9341 27.4413 15.6457 27.154C15.3643 26.8746 15.3203 26.442 15.5486 26.0925C15.6207 25.9824 15.7128 25.8832 15.8069 25.7891C16.8613 24.7307 17.9167 23.6733 18.9732 22.6179C19.4017 22.1893 19.8784 22.1763 20.3039 22.5988C21.3914 23.6803 22.4739 24.7667 23.5533 25.8572C23.9809 26.2898 24.0129 26.8065 23.6534 27.167C23.299 27.5214 22.7753 27.4844 22.3437 27.0568C21.7499 26.47 21.1661 25.8732 20.5603 25.2644H20.5573Z\"\r\n              fill=\"#F9F9F9\"/>\r\n          </svg>\r\n        </div>\r\n        <div class=\"f-14 fc-black fw-normal\">\r\n          <span class=\"fc-coral fw-medium\">{{ 'browse' | translate }}</span>\r\n        </div>\r\n        <div class=\"fs-10 fc-dark-gray\">\r\n          {{ 'addMultiAttachments' | translate }}\r\n        </div>\r\n      </div>\r\n    </section>\r\n  }\r\n\r\n  @if (attachments?.length) {\r\n    <div\r\n      class=\"table-responsive full\"\r\n      cdkDropList\r\n      [cdkDropListData]=\"attachments\"\r\n      (cdkDropListDropped)=\"drop($event)\"\r\n    >\r\n      <table mat-table [dataSource]=\"dataSource\">\r\n\r\n        <!-- index Column -->\r\n        <ng-container matColumnDef=\"index\">\r\n          <th mat-header-cell *matHeaderCellDef>\r\n            <ds-button\r\n              [matTooltip]=\"'downloadAll' | translate\"\r\n              square icon size=\"small\"\r\n              (click)=\"downloadAllAttachments($event)\"\r\n              class=\"icon-btn-shadow\">\r\n              @if (loading) {\r\n                <ds-icon class=\"sfi sfi-spinner d-inline-block spin fc-coral fs-30-imp\"></ds-icon>\r\n              } @else {\r\n                <ds-icon\r\n                  icon=\"download\"\r\n                  class=\"fs-20 fs-md-17 fc-purple\"></ds-icon>\r\n              }\r\n            </ds-button>\r\n          </th>\r\n          <td mat-cell *matCellDef=\"let element; let i = index\">{{ i + 1 + pageSize * (pageNumber) }}</td>\r\n        </ng-container>\r\n\r\n        <!-- Name Column -->\r\n        <ng-container matColumnDef=\"file\">\r\n          <th mat-header-cell *matHeaderCellDef>{{ 'FileName' | translate }}</th>\r\n          <td mat-cell *matCellDef=\"let element\">\r\n            <app-file-uploader\r\n              [allowedExtensions]=\"allowedExtensions\"\r\n              [displayedFiles]=\"[element]\"\r\n              name=\"attachment\"\r\n              [showActions]=\"true\"\r\n              [isReadOnly]=\"true\"\r\n              [customDownload]=\"customDownload\"\r\n              (downloadActionClicked)=\"customDownloadAction($event)\"\r\n              [multiple]=\"true\">\r\n            </app-file-uploader>\r\n          </td>\r\n        </ng-container>\r\n\r\n        <!-- Description Column -->\r\n        <ng-container matColumnDef=\"description\">\r\n          <th mat-header-cell *matHeaderCellDef>{{ 'FileDescription' | translate }}</th>\r\n          <td mat-cell *matCellDef=\"let element\">\r\n            <a\r\n              class=\"fw-medium fc-black underline cursor-pointer fs-12\"\r\n              [hidden]=\"!element?.['fileDescription']\"\r\n              (click)=\"$event.stopPropagation(); fileDescriptionAnchor.popover.open()\"\r\n              [satPopoverAnchor]=\"fileDescriptionPopover\"\r\n              #fileDescriptionAnchor=\"satPopoverAnchor\"\r\n              [matTooltip]=\"element?.['fileDescription']\">\r\n              {{ element?.['fileDescription']?.length > 10 ? (element?.['fileDescription'] | slice : 0 : 10) + '....' : element?.['fileDescription'] }}\r\n            </a>\r\n            <sat-popover\r\n              #fileDescriptionPopover\r\n              [anchor]=\"fileDescriptionAnchor\"\r\n              [hasBackdrop]=\"true\"\r\n              [restoreFocus]=\"false\"\r\n              verticalAlign=\"below\"\r\n              horizontalAlign=\"center\">\r\n              <div class=\"default-popover p-3 fs-14 text-break view-note-popover\">\r\n                <bdi class=\"fc-black\">{{ element?.['fileDescription'] }}</bdi>\r\n              </div>\r\n            </sat-popover>\r\n          </td>\r\n        </ng-container>\r\n\r\n        <!-- Comment Column -->\r\n        <ng-container matColumnDef=\"comment\">\r\n          <th mat-header-cell *matHeaderCellDef>{{ 'comment' | translate }}</th>\r\n          <td mat-cell *matCellDef=\"let element\">\r\n            <a\r\n              class=\"fw-medium fc-black underline cursor-pointer fs-12\"\r\n              [hidden]=\"!element?.['attachmentcomment']\"\r\n              (click)=\"$event.stopPropagation(); commentsAnchor.popover.open()\"\r\n              [satPopoverAnchor]=\"commentsPopover\"\r\n              [matTooltip]=\"element?.['attachmentcomment']\"\r\n              #commentsAnchor=\"satPopoverAnchor\">\r\n              {{ element?.['attachmentcomment']?.length > 10 ? (element?.['attachmentcomment'] | slice : 0 : 10) + '....' : element?.['attachmentcomment'] }}\r\n            </a>\r\n            <sat-popover\r\n              #commentsPopover\r\n              [anchor]=\"commentsAnchor\"\r\n              [hasBackdrop]=\"true\"\r\n              [restoreFocus]=\"false\"\r\n              verticalAlign=\"below\"\r\n              horizontalAlign=\"center\">\r\n              <div class=\"default-popover p-3 fs-14 text-break view-note-popover\">\r\n                <bdi class=\"fc-black\">{{ element?.['attachmentcomment'] }}</bdi>\r\n              </div>\r\n            </sat-popover>\r\n          </td>\r\n        </ng-container>\r\n\r\n        <ng-container matColumnDef=\"actions\">\r\n          <th mat-header-cell *matHeaderCellDef></th>\r\n          <td mat-cell *matCellDef=\"let element; let i = index\">\r\n            @if (!isReadOnly) {\r\n              <td>\r\n                <div class=\"d-flex gap-2\">\r\n                  <ds-button\r\n                    square\r\n                    icon\r\n                    size=\"small\"\r\n                    (click)=\"deleteAttachments(i, element)\"\r\n                    class=\"icon-btn-shadow\">\r\n                    <ds-icon icon=\"trash\" class=\"fs-20 fs-md-17 fc-coral\"></ds-icon>\r\n                  </ds-button>\r\n\r\n                  <ds-button\r\n                    square\r\n                    icon\r\n                    size=\"small\"\r\n                    (click)=\"editRow(element, i)\"\r\n                    class=\"icon-btn-shadow\">\r\n                    <ds-icon icon=\"pen\" class=\"fs-20 fs-md-17 fc-purple\"></ds-icon>\r\n                  </ds-button>\r\n                </div>\r\n              </td>\r\n            }\r\n          </td>\r\n        </ng-container>\r\n\r\n        <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\r\n        <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\r\n      </table>\r\n\r\n      <mat-paginator\r\n        #paginator\r\n        [pageSizeOptions]=\"[5]\"\r\n        (page)=\"onPaginateChange($event)\"\r\n        [length]=\"attachments.length\"\r\n        [pageSize]=\"pageSize\"\r\n        showFirstLastButtons></mat-paginator>\r\n    </div>\r\n  }\r\n\r\n  @if (!isReadOnly && attachments?.length && attachments?.length < attachmentsMax) {\r\n    <div class=\"text-center full mt-3\">\r\n      <ds-button\r\n        shape=\"{{ attachments?.length ? 'outline' : '' }}\"\r\n        [ngClass]=\"{ 'full-add-btn w-100 pt-1': attachments?.length }\"\r\n        (click)=\"addAttachment(); $event.stopPropagation()\">\r\n        <ds-icon slot=\"prefix\" icon=\"plus\" class=\"fs-22 pb-1\"></ds-icon>\r\n        {{ 'addAttachments' | translate }}\r\n      </ds-button>\r\n    </div>\r\n  }\r\n</div>\r\n"]}
|
|
234
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment-section.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/attachment-section/attachment-section.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/attachment-section/attachment-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, CUSTOM_ELEMENTS_SCHEMA, DestroyRef, EventEmitter, forwardRef, inject, Input, OnDestroy, Output, ViewChild} from '@angular/core';\r\nimport {AttachmentSectionDataComponent} from '../add-attachment-section/add-attachment-section.component';\r\nimport {CdkDrag, CdkDragDrop, CdkDropList, moveItemInArray} from '@angular/cdk/drag-drop';\r\nimport {SatPopoverModule} from '@ncstate/sat-popover';\r\nimport {MatTooltip} from \"@angular/material/tooltip\";\r\nimport {NgClass, NgForOf, NgIf, SlicePipe} from \"@angular/common\";\r\nimport {DocsUploaderComponent} from '../doc-uploader/docs-uploader.component';\r\nimport {DeleteDialogComponent} from \"../../dialogs/delete-dialog/delete-dialog.component\";\r\nimport {ControlValueAccessorDirective} from \"../control-value-accessor.directive\";\r\nimport {MatDialog} from \"@angular/material/dialog\";\r\nimport {NG_VALUE_ACCESSOR} from '@angular/forms';\r\nimport {MatPaginator} from \"@angular/material/paginator\";\r\nimport {\r\n  MatCell,\r\n  MatCellDef,\r\n  MatColumnDef,\r\n  MatHeaderCell,\r\n  MatHeaderCellDef,\r\n  MatHeaderRow,\r\n  MatHeaderRowDef,\r\n  MatRow,\r\n  MatRowDef,\r\n  MatTable,\r\n  MatTableDataSource\r\n} from \"@angular/material/table\";\r\nimport { FormLabelComponent } from '../form-label/form-label.component';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport {TranslatePipe} from \"../../../../pipes/translate.pipe\";\r\n\r\n\r\n@Component({\r\n  selector: 'app-attachment-section',\r\n  templateUrl: './attachment-section.component.html',\r\n  styleUrls: ['./attachment-section.component.scss'],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => AttachmentSectionComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n  imports: [\r\n    SatPopoverModule,\r\n    MatTooltip,\r\n    NgClass,\r\n    CdkDropList,\r\n    DocsUploaderComponent,\r\n    CdkDrag,\r\n    SlicePipe,\r\n    MatPaginator,\r\n    MatTable,\r\n    MatColumnDef,\r\n    MatCell,\r\n    MatCellDef,\r\n    MatHeaderCellDef,\r\n    MatHeaderCell,\r\n    MatRow,\r\n    MatHeaderRow,\r\n    MatHeaderRowDef,\r\n    MatRowDef,\r\n    FormLabelComponent,\r\n    TranslatePipe\r\n  ],\r\n  standalone: true\r\n})\r\nexport class AttachmentSectionComponent extends ControlValueAccessorDirective<any> implements AfterViewInit {\r\n  @Input() className = 'info-section';\r\n  @Output() downloadActionClicked = new EventEmitter();\r\n  @Input() customDownload: boolean;\r\n\r\n  @Input() attachmentsMax = 1000;\r\n  @Input() isSortable = false;\r\n  @Input() downloadAll = false;\r\n  popupData: any = {};\r\n  @Input() isRequired: boolean = false;\r\n  @Input() descriptionRequired: boolean;\r\n  @Input() commentsRequired: boolean;\r\n  @Input() allowedExtensions = '';\r\n  @Output() emitedValue = new EventEmitter();\r\n  dialog = inject(MatDialog);\r\n  displayedColumns: string[] = [\"index\", \"file\", \"description\", \"comment\", \"actions\"];\r\n  dataSource: MatTableDataSource<any>;\r\n  @ViewChild('paginator') paginator: MatPaginator;\r\n  totalRecords: number = 0;\r\n  pageSize: number = 5;\r\n  pageNumber: number = 0;\r\n  destroyRef = inject(DestroyRef);\r\n\r\n  override ngOnInit(): void {\r\n    super.ngOnInit()\r\n    if (this.control.value) {\r\n      this.attachments = this.control.value\r\n    }\r\n    /*if (this.attachments) {\r\n      this.attachments.forEach(element => {\r\n        element.name = element.fileName;\r\n      });\r\n    }*/\r\n    this.actionStateService.resetAction$\r\n    .pipe(takeUntilDestroyed(this.destroyRef))\r\n    .subscribe(res => {\r\n      if (!this.isReadOnly && this.control.enabled) {\r\n        this.control.reset();\r\n      }\r\n    });\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.addDataToTable();\r\n    this.paginator._intl.itemsPerPageLabel = this.i18n.translate('itemsPerPage')\r\n  }\r\n\r\n  onPaginateChange(event: any) {\r\n    this.pageNumber = event.pageIndex\r\n  }\r\n\r\n  drop(event: CdkDragDrop<string[]>) {\r\n    moveItemInArray(this.attachments, event.previousIndex, event.currentIndex);\r\n  }\r\n\r\n\r\n  resetAttachmentData() {\r\n    if (!this.isReadOnly) {\r\n      this.attachments = [];\r\n      this.emitedValue.emit(this.attachments);\r\n    }\r\n  }\r\n\r\n  addDataToTable(){\r\n    this.dataSource = new MatTableDataSource(this.attachments);\r\n    this.totalRecords = this.dataSource.data.length;\r\n    this.dataSource.paginator = this.paginator;\r\n  }\r\n\r\n  handleEmitValue(data: any, fieldName: string) {\r\n    this.popupData[fieldName] = data;\r\n  }\r\n\r\n  addAttachment(): void {\r\n    const dialogRef = this.dialog.open(AttachmentSectionDataComponent, {\r\n      panelClass: ['main-popup', 'add-attachment-dialog'],\r\n      data: {\r\n        attachmentListData: null,\r\n        data: this.allowedExtensions,\r\n        isRequired: this.isRequired,\r\n        multiple: this.multiple,\r\n        attachments: this.attachments,\r\n        descriptionRequired: this.descriptionRequired,\r\n        commentsRequired: this.commentsRequired\r\n      }\r\n    });\r\n    dialogRef.afterClosed().subscribe((resultData) => {\r\n      if (resultData != 'close') {\r\n        if (resultData?.attachmentId) {\r\n          this.attachments.push(resultData);\r\n    this.addDataToTable();\r\n\r\n        }\r\n      }\r\n      this.control.setValue(this.attachments)\r\n    });\r\n  }\r\n\r\n  deleteAttachments(index: number, item: any) {\r\n    const dialogRef = this.dialog.open(DeleteDialogComponent, {\r\n      panelClass: ['main-popup', 'add-attachment-dialog']\r\n    });\r\n    dialogRef.afterClosed().subscribe((resultData) => {\r\n      if (resultData == 'yes') {\r\n        this.deleteAttachment(index, item);\r\n      }\r\n    });\r\n  }\r\n\r\n  deleteAttachment(index: number, item: any) {\r\n    this.attachments = this.attachments.filter((row: any) => {\r\n      return row.attachmentId != item.attachmentId;\r\n    });\r\n    this.addDataToTable();\r\n    this.control.setValue(this.attachments)\r\n  }\r\n\r\n  editRow(rowData, index): void {\r\n    const dialogRef = this.dialog.open(AttachmentSectionDataComponent, {\r\n      panelClass: ['main-popup', 'add-attachment-dialog'],\r\n      data: {\r\n        attachmentListData: Object.assign(rowData),\r\n        data: this.allowedExtensions,\r\n        isRequired: this.isRequired,\r\n        multiple: this.multiple,\r\n        attachments: this.attachments,\r\n\r\n      }\r\n    });\r\n    dialogRef.afterClosed().subscribe((resultData) => {\r\n      if (resultData != 'close') {\r\n        if (resultData?.attachmentId) {\r\n          this.attachments[index] = resultData;\r\n          this.emitedValue.emit(this.attachments);\r\n          this.addDataToTable();\r\n          this.control.setValue(this.attachments)\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  downloadAllAttachments(event) {\r\n    this.loading = true\r\n    const downloads = this.attachments.map((file) => this.downloadFile(event, file));\r\n    Promise.all(downloads)\r\n      .then(() => {\r\n        this.loading = false\r\n      })\r\n      .catch((error) => {\r\n        this.loading = false\r\n      });\r\n  }\r\n\r\n  downloadFile(event, field): Promise<void> {\r\n    return new Promise((resolve, reject) => {\r\n      this.coreService.loadFile(field.attachmentId).pipe(\r\n        takeUntilDestroyed(this.destroyRef)\r\n      ).subscribe(\r\n        (responseObject: { body: any; }) => {\r\n          const fileInformation = responseObject.body;\r\n          this.coreService.saveFile(fileInformation)\r\n          resolve();\r\n        },\r\n        error => {\r\n          this.toasterService.error(error.error?.['message']);\r\n        }\r\n      );\r\n    });\r\n  }\r\n\r\n  customDownloadAction(event){\r\n    this.downloadActionClicked.emit(event);\r\n  }\r\n\r\n}\r\n","<div class=\"mt-2 p-0\">\r\n  @if(label){\r\n    <app-form-label [label]=\"label\" [optional]=\"(required || mandatory ? false : true) && !isReadOnly\" [tooltip]=\"tooltip\"></app-form-label>\r\n  }\r\n\r\n  @if (!attachments?.length && !isReadOnly) {\r\n    <section\r\n      [ngClass]=\"insideTable ? 'file-uploader-table' : 'file-uploader'\"\r\n      class=\"mb-2\"\r\n      [class.insideTableStyle]=\"insideTable\"\r\n      (click)=\"addAttachment()\">\r\n      <div\r\n        [ngClass]=\"insideTable ? 'file-uploader-table-dev' : ''\"\r\n        class=\"file-uploader-input\">\r\n        <div class=\"icon mb-1\">\r\n          <svg\r\n            [ngClass]=\"insideTable ? 'file-uploader-table-svg' : ''\"\r\n            width=\"41\"\r\n            height=\"38\"\r\n            viewBox=\"0 0 41 38\"\r\n            fill=\"none\"\r\n            xmlns=\"http://www.w3.org/2000/svg\">\r\n            <path\r\n              d=\"M0 22.1947V20.6736C0.0971303 20.1019 0.070094 19.5141 0.276371 18.9533C1.28372 16.2086 3.21231 14.5023 6.0421 13.8094C6.70499 13.6472 6.68497 13.6632 6.69899 12.9843C6.73203 11.3321 6.99839 9.71992 7.62423 8.17986C8.86289 5.13678 10.9467 2.83969 13.8816 1.39175C17.168 -0.230424 20.5956 -0.450719 24.0553 0.81598C27.4929 2.07467 29.9622 4.41581 31.4802 7.74828C31.7786 8.40316 32.027 9.08307 32.1712 9.79202C32.2402 10.1315 32.4035 10.2566 32.7529 10.3107C36.7012 10.9165 39.3358 13.1255 40.6946 16.8735C40.9069 17.4603 40.9199 18.0731 40.9599 18.6829C40.9649 18.7601 40.9389 18.8442 41 18.9113V20.5124C40.9109 20.995 40.969 21.4937 40.8608 21.9734C40.5244 23.4614 39.8454 24.7821 38.8501 25.9297C37.4522 27.5418 35.7059 28.5882 33.6161 29.0519C32.791 29.2351 31.9499 29.2521 31.1117 29.2922C30.6571 29.3142 30.584 29.193 30.592 28.7484C30.6451 25.8446 29.802 23.2571 27.8624 21.0591C25.9979 18.9463 23.6597 17.7167 20.867 17.4012C18.8553 17.1739 16.9057 17.4593 15.0612 18.3395C11.8319 19.8816 9.81416 22.4069 8.96102 25.8696C8.74273 26.7538 8.68265 27.658 8.70568 28.5702C8.7217 29.2111 8.60254 29.3122 7.95968 29.2972C5.95098 29.2511 4.10551 28.7234 2.58146 27.3596C1.07644 26.0168 0.0680913 24.3996 0.0400537 22.3028C0.0400537 22.2607 0.0250336 22.2257 0 22.1937V22.1947Z\"\r\n              fill=\"#DEE0E2\"/>\r\n            <path\r\n              d=\"M29.0303 28.2632C29.0604 33.4031 24.8657 37.6187 19.6838 37.6548C14.5169 37.6908 10.2852 33.4952 10.2521 28.3042C10.2201 23.1403 14.4297 18.9126 19.6227 18.8946C24.8037 18.8766 28.9993 23.0542 29.0303 28.2632Z\"\r\n              fill=\"#8E9AA0\"/>\r\n            <path\r\n              d=\"M20.5573 25.2644C20.4622 25.4477 20.5012 25.5939 20.5012 25.734C20.4982 28.2154 20.5002 30.6957 20.4982 33.177C20.4982 33.8099 20.2339 34.1704 19.7462 34.2234C19.2645 34.2765 18.88 33.9831 18.8169 33.5025C18.7959 33.3443 18.7969 33.183 18.7969 33.0238C18.7959 30.5826 18.7969 28.1423 18.7969 25.701C18.7969 25.5728 18.7969 25.4447 18.7969 25.2003C18.1971 25.8031 17.6774 26.3288 17.1527 26.8505C17.0115 26.9907 16.8683 27.1349 16.7061 27.2471C16.3566 27.4864 15.9341 27.4413 15.6457 27.154C15.3643 26.8746 15.3203 26.442 15.5486 26.0925C15.6207 25.9824 15.7128 25.8832 15.8069 25.7891C16.8613 24.7307 17.9167 23.6733 18.9732 22.6179C19.4017 22.1893 19.8784 22.1763 20.3039 22.5988C21.3914 23.6803 22.4739 24.7667 23.5533 25.8572C23.9809 26.2898 24.0129 26.8065 23.6534 27.167C23.299 27.5214 22.7753 27.4844 22.3437 27.0568C21.7499 26.47 21.1661 25.8732 20.5603 25.2644H20.5573Z\"\r\n              fill=\"#F9F9F9\"/>\r\n          </svg>\r\n        </div>\r\n        <div class=\"f-14 fc-black fw-normal\">\r\n          <span class=\"fc-coral fw-medium\">{{ 'browse' | translate }}</span>\r\n        </div>\r\n        <div class=\"fs-10 fc-dark-gray\">\r\n          {{ 'addMultiAttachments' | translate }}\r\n        </div>\r\n      </div>\r\n    </section>\r\n  }\r\n\r\n  @if (attachments?.length) {\r\n    <div\r\n      class=\"table-responsive full\"\r\n      cdkDropList\r\n      [cdkDropListData]=\"attachments\"\r\n      (cdkDropListDropped)=\"drop($event)\"\r\n    >\r\n      <table mat-table [dataSource]=\"dataSource\">\r\n\r\n        <!-- index Column -->\r\n        <ng-container matColumnDef=\"index\">\r\n          <th mat-header-cell *matHeaderCellDef>\r\n            <ds-button\r\n              [matTooltip]=\"'downloadAll' | translate\"\r\n              square icon size=\"small\"\r\n              (click)=\"downloadAllAttachments($event)\"\r\n              class=\"icon-btn-shadow\">\r\n              @if (loading) {\r\n                <ds-icon class=\"sfi sfi-spinner d-inline-block spin fc-coral fs-30-imp\"></ds-icon>\r\n              } @else {\r\n                <ds-icon\r\n                  icon=\"download\"\r\n                  class=\"fs-20 fs-md-17 fc-purple\"></ds-icon>\r\n              }\r\n            </ds-button>\r\n          </th>\r\n          <td mat-cell *matCellDef=\"let element; let i = index\">{{ i + 1 + pageSize * (pageNumber) }}</td>\r\n        </ng-container>\r\n\r\n        <!-- Name Column -->\r\n        <ng-container matColumnDef=\"file\">\r\n          <th mat-header-cell *matHeaderCellDef>{{ 'FileName' | translate }}</th>\r\n          <td mat-cell *matCellDef=\"let element\">\r\n            <app-file-uploader\r\n              [allowedExtensions]=\"allowedExtensions\"\r\n              [displayedFiles]=\"[element]\"\r\n              name=\"attachment\"\r\n              [showActions]=\"true\"\r\n              [isReadOnly]=\"true\"\r\n              [customDownload]=\"customDownload\"\r\n              (downloadActionClicked)=\"customDownloadAction($event)\"\r\n              [multiple]=\"true\">\r\n            </app-file-uploader>\r\n          </td>\r\n        </ng-container>\r\n\r\n        <!-- Description Column -->\r\n        <ng-container matColumnDef=\"description\">\r\n          <th mat-header-cell *matHeaderCellDef>{{ 'FileDescription' | translate }}</th>\r\n          <td mat-cell *matCellDef=\"let element\">\r\n            <a\r\n              class=\"fw-medium fc-black underline cursor-pointer fs-12\"\r\n              [hidden]=\"!element?.['fileDescription']\"\r\n              (click)=\"$event.stopPropagation(); fileDescriptionAnchor.popover.open()\"\r\n              [satPopoverAnchor]=\"fileDescriptionPopover\"\r\n              #fileDescriptionAnchor=\"satPopoverAnchor\"\r\n              [matTooltip]=\"element?.['fileDescription']\">\r\n              {{ element?.['fileDescription']?.length > 10 ? (element?.['fileDescription'] | slice : 0 : 10) + '....' : element?.['fileDescription'] }}\r\n            </a>\r\n            <sat-popover\r\n              #fileDescriptionPopover\r\n              [anchor]=\"fileDescriptionAnchor\"\r\n              [hasBackdrop]=\"true\"\r\n              [restoreFocus]=\"false\"\r\n              verticalAlign=\"below\"\r\n              horizontalAlign=\"center\">\r\n              <div class=\"default-popover p-3 fs-14 text-break view-note-popover\">\r\n                <bdi class=\"fc-black\">{{ element?.['fileDescription'] }}</bdi>\r\n              </div>\r\n            </sat-popover>\r\n          </td>\r\n        </ng-container>\r\n\r\n        <!-- Comment Column -->\r\n        <ng-container matColumnDef=\"comment\">\r\n          <th mat-header-cell *matHeaderCellDef>{{ 'comment' | translate }}</th>\r\n          <td mat-cell *matCellDef=\"let element\">\r\n            <a\r\n              class=\"fw-medium fc-black underline cursor-pointer fs-12\"\r\n              [hidden]=\"!element?.['attachmentcomment']\"\r\n              (click)=\"$event.stopPropagation(); commentsAnchor.popover.open()\"\r\n              [satPopoverAnchor]=\"commentsPopover\"\r\n              [matTooltip]=\"element?.['attachmentcomment']\"\r\n              #commentsAnchor=\"satPopoverAnchor\">\r\n              {{ element?.['attachmentcomment']?.length > 10 ? (element?.['attachmentcomment'] | slice : 0 : 10) + '....' : element?.['attachmentcomment'] }}\r\n            </a>\r\n            <sat-popover\r\n              #commentsPopover\r\n              [anchor]=\"commentsAnchor\"\r\n              [hasBackdrop]=\"true\"\r\n              [restoreFocus]=\"false\"\r\n              verticalAlign=\"below\"\r\n              horizontalAlign=\"center\">\r\n              <div class=\"default-popover p-3 fs-14 text-break view-note-popover\">\r\n                <bdi class=\"fc-black\">{{ element?.['attachmentcomment'] }}</bdi>\r\n              </div>\r\n            </sat-popover>\r\n          </td>\r\n        </ng-container>\r\n\r\n        <ng-container matColumnDef=\"actions\">\r\n          <th mat-header-cell *matHeaderCellDef></th>\r\n          <td mat-cell *matCellDef=\"let element; let i = index\">\r\n            @if (!isReadOnly) {\r\n              <td>\r\n                <div class=\"d-flex gap-2\">\r\n                  <ds-button\r\n                    square\r\n                    icon\r\n                    size=\"small\"\r\n                    (click)=\"deleteAttachments(i, element)\"\r\n                    class=\"icon-btn-shadow\">\r\n                    <ds-icon icon=\"trash\" class=\"fs-20 fs-md-17 fc-coral\"></ds-icon>\r\n                  </ds-button>\r\n\r\n                  <ds-button\r\n                    square\r\n                    icon\r\n                    size=\"small\"\r\n                    (click)=\"editRow(element, i)\"\r\n                    class=\"icon-btn-shadow\">\r\n                    <ds-icon icon=\"pen\" class=\"fs-20 fs-md-17 fc-purple\"></ds-icon>\r\n                  </ds-button>\r\n                </div>\r\n              </td>\r\n            }\r\n          </td>\r\n        </ng-container>\r\n\r\n        <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\r\n        <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\r\n      </table>\r\n\r\n      <mat-paginator\r\n        #paginator\r\n        [pageSizeOptions]=\"[5]\"\r\n        (page)=\"onPaginateChange($event)\"\r\n        [length]=\"attachments.length\"\r\n        [pageSize]=\"pageSize\"\r\n        showFirstLastButtons></mat-paginator>\r\n    </div>\r\n  }\r\n\r\n  @if (!isReadOnly && attachments?.length && attachments?.length < attachmentsMax) {\r\n    <div class=\"text-center full mt-3\">\r\n      <ds-button\r\n        shape=\"{{ attachments?.length ? 'outline' : '' }}\"\r\n        [ngClass]=\"{ 'full-add-btn w-100 pt-1': attachments?.length }\"\r\n        (click)=\"addAttachment(); $event.stopPropagation()\">\r\n        <ds-icon slot=\"prefix\" icon=\"plus\" class=\"fs-22 pb-1\"></ds-icon>\r\n        {{ 'addAttachments' | translate }}\r\n      </ds-button>\r\n    </div>\r\n  }\r\n</div>\r\n"]}
|
package/fesm2022/bpm-core.mjs
CHANGED
|
@@ -4421,29 +4421,40 @@ class AttachmentSectionDataComponent extends ControlValueAccessorDirective {
|
|
|
4421
4421
|
};
|
|
4422
4422
|
}
|
|
4423
4423
|
addAttachments() {
|
|
4424
|
-
const
|
|
4424
|
+
const newObj = {
|
|
4425
4425
|
fileDescription: this.formGroup.controls['description'].value,
|
|
4426
4426
|
attachmentcomment: this.formGroup.controls['comments'].value,
|
|
4427
4427
|
fileComments: this.formGroup.controls['comments'].value,
|
|
4428
4428
|
fileName: this.formGroup.controls['file'].value.fileName,
|
|
4429
|
+
attachmentId: this.formGroup.controls['file'].value.attachmentId,
|
|
4429
4430
|
mimeType: this.formGroup.controls['file'].value.mimeType,
|
|
4430
|
-
fileContents: this.formGroup.controls['file'].value.fileContents,
|
|
4431
4431
|
};
|
|
4432
|
-
this.
|
|
4433
|
-
|
|
4434
|
-
|
|
4435
|
-
|
|
4432
|
+
this.dialogRef.close(newObj);
|
|
4433
|
+
/* const data = {
|
|
4434
|
+
fileDescription: this.formGroup.controls['description'].value,
|
|
4435
|
+
attachmentcomment: this.formGroup.controls['comments'].value,
|
|
4436
|
+
fileComments: this.formGroup.controls['comments'].value,
|
|
4437
|
+
fileName: this.formGroup.controls['file'].value.fileName,
|
|
4438
|
+
mimeType: this.formGroup.controls['file'].value.mimeType,
|
|
4439
|
+
fileContents: this.formGroup.controls['file'].value.fileContents,
|
|
4440
|
+
};
|
|
4441
|
+
this.uploading = true;
|
|
4442
|
+
this.coreService.getAttachments(data).pipe(
|
|
4443
|
+
takeUntilDestroyed(this.destroyRef)
|
|
4444
|
+
).subscribe((Response: any) => {
|
|
4445
|
+
this.uploading = false;
|
|
4446
|
+
if (Response) {
|
|
4436
4447
|
const newObj = {
|
|
4437
|
-
|
|
4438
|
-
|
|
4439
|
-
|
|
4440
|
-
|
|
4441
|
-
|
|
4442
|
-
|
|
4448
|
+
fileDescription: this.formGroup.controls['description'].value,
|
|
4449
|
+
attachmentcomment: this.formGroup.controls['comments'].value,
|
|
4450
|
+
fileComments: this.formGroup.controls['comments'].value,
|
|
4451
|
+
fileName: this.formGroup.controls['file'].value.fileName,
|
|
4452
|
+
attachmentId: Response.attachment.attachmentId ?? this.formGroup.controls['file'].value.attachmentId,
|
|
4453
|
+
mimeType: this.formGroup.controls['file'].value.mimeType,
|
|
4443
4454
|
};
|
|
4444
4455
|
this.dialogRef.close(newObj);
|
|
4445
|
-
|
|
4446
|
-
|
|
4456
|
+
}
|
|
4457
|
+
});*/
|
|
4447
4458
|
}
|
|
4448
4459
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AttachmentSectionDataComponent, deps: [{ token: i0.Injector }, { token: CoreI18nService }, { token: i2$1.ToastrService }, { token: CoreService }, { token: i3.DomSanitizer }, { token: i4.FormBuilder }, { token: ActionStateService }, { token: i1$1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
|
|
4449
4460
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: AttachmentSectionDataComponent, isStandalone: true, selector: "app-add-attachment-section", inputs: { hasColumnBreak: "hasColumnBreak", section: "section" }, providers: [
|
|
@@ -4508,11 +4519,11 @@ class AttachmentSectionComponent extends ControlValueAccessorDirective {
|
|
|
4508
4519
|
if (this.control.value) {
|
|
4509
4520
|
this.attachments = this.control.value;
|
|
4510
4521
|
}
|
|
4511
|
-
if (this.attachments) {
|
|
4512
|
-
|
|
4513
|
-
|
|
4514
|
-
|
|
4515
|
-
}
|
|
4522
|
+
/*if (this.attachments) {
|
|
4523
|
+
this.attachments.forEach(element => {
|
|
4524
|
+
element.name = element.fileName;
|
|
4525
|
+
});
|
|
4526
|
+
}*/
|
|
4516
4527
|
this.actionStateService.resetAction$
|
|
4517
4528
|
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
4518
4529
|
.subscribe(res => {
|