@rangertechnologies/ngnxt 2.1.119 → 2.1.121
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/environments/version.mjs +5 -5
- package/esm2022/lib/components/custom-calendar/custom-calendar.component.mjs +3 -2
- package/esm2022/lib/components/custom-table/custom-table.component.mjs +3 -2
- package/esm2022/lib/components/datatable/datatable.component.mjs +167 -22
- package/esm2022/lib/components/file-upload/file-upload.component.mjs +3 -2
- package/esm2022/lib/components/table-appendix/table-appendix.component.mjs +3 -2
- package/esm2022/lib/pages/booklet/booklet.component.mjs +38 -4
- package/esm2022/lib/pages/builder/element/element.component.mjs +39 -26
- package/esm2022/lib/pages/builder/properties/properties.component.mjs +680 -209
- package/esm2022/lib/pages/questionbook/questionbook.component.mjs +31 -4
- package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +39 -12
- package/esm2022/lib/services/change.service.mjs +1 -3
- package/esm2022/lib/services/form-builder.service.mjs +23 -4
- package/fesm2022/rangertechnologies-ngnxt.mjs +1022 -284
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
- package/lib/components/datatable/datatable.component.d.ts +14 -3
- package/lib/pages/booklet/booklet.component.d.ts +1 -0
- package/lib/pages/builder/element/element.component.d.ts +2 -0
- package/lib/pages/builder/properties/properties.component.d.ts +602 -41
- package/lib/pages/questionbook/questionbook.component.d.ts +3 -2
- package/lib/pages/questionnaire/questionnaire.component.d.ts +3 -2
- package/lib/services/form-builder.service.d.ts +14 -1
- package/package.json +1 -1
- package/rangertechnologies-ngnxt-2.1.121.tgz +0 -0
- package/rangertechnologies-ngnxt-2.1.119.tgz +0 -0
|
@@ -63,7 +63,8 @@ export class FileUploadComponent {
|
|
|
63
63
|
initializeFileConfigs() {
|
|
64
64
|
if (this.question?.fieldsMeta) {
|
|
65
65
|
try {
|
|
66
|
-
|
|
66
|
+
// SKS20MAR25 check if question fieldsmeta is string
|
|
67
|
+
const metaData = typeof this.question['fieldsMeta'] === 'object' ? this.question['fieldsMeta'] || [{}] : JSON.parse(this.question['fieldsMeta']);
|
|
67
68
|
const fileConfig = metaData[0]; // Get first config object
|
|
68
69
|
if (fileConfig) {
|
|
69
70
|
this.allowedFileTypes = fileConfig.allowedTypes || [];
|
|
@@ -276,4 +277,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
276
277
|
}], error: [{
|
|
277
278
|
type: Input
|
|
278
279
|
}] } });
|
|
279
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/file-upload/file-upload.component.ts","../../../../../../projects/nxt-app/src/lib/components/file-upload/file-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit,Output,EventEmitter, Input ,ElementRef, OnChanges,SimpleChanges} from '@angular/core';\n// HA 19DEC23 imported translation service\nimport { I18nService } from '../../i18n.service';\nimport { SharedService } from '../../services/shared.service';\nimport { DataService } from '../../services/data.service';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\n@Component({\n  selector: 'app-file-upload',\n  templateUrl: './file-upload.component.html',\n  styleUrls: ['./file-upload.component.css']\n})\nexport class FileUploadComponent implements OnInit,OnChanges {\n  @Output() selectedFileData = new EventEmitter<any[]>();\n  @Output() deletedFileData = new EventEmitter<any>();\n  @Input() allFiles;\n  @Input() limitFileUploading;\n  @Input() isDeleteFileButtonVisible;\n  @Input() isShowNoFileIcon;\n  @Input() tableFile;  // file Upload from table\n  @Input() question;\n  @Input() error:any;\n//RS 09JAN2025\n  public allowedFileTypes: string[] = [];\n  public maxFileSize: number = 0;  // in bytes(Binary)\n  public maxFiles: number = 4;     // default limit\n  public validationErrors: string[] = [];\n \n\n  public selectedFileNameArray: string[] = [];\n  public copyOfInputAllFiles;\n  public copyOfFileUploadingLimit;\n  public fileUrl;\n  public showFile = false;\n  public isImage = false;\n  public fileName = '';\n  currentFile: any;\n  constructor(private SharedService: SharedService,  private dataService: DataService,private sanitizer: DomSanitizer,\n    public i18nService: I18nService\n  ) { }\n  //RS 09JAN2025\n  ngOnInit() {\n    this.initializeFileConfigs();\n   }\n  // VD 03May24 file upload fix\n  // onFileUpload(event: any) {\n  //   const fileUploaderElement: HTMLElement = document.getElementById(\n  //     'fileUpload'\n  //   ) as HTMLElement;\n  //   fileUploaderElement.click();\n  // }\n\n  ngOnChanges(simpleChanges: SimpleChanges) {\n    console.log('simple changes', simpleChanges);\n    if (simpleChanges.allFiles) {  //SKS5NOV25\n      this.copyOfInputAllFiles = simpleChanges.allFiles.currentValue || [];\n    }\n\n    if (simpleChanges.limitFileUploading) {\n      this.copyOfFileUploadingLimit = simpleChanges.limitFileUploading?.currentValue;\n    }\n\n  }\n\n  //RS 09JAN2025 Initializes file upload settings (allowed types, max size, and max files) by parsing metadata from fieldsMeta\n   initializeFileConfigs() {\n    if (this.question?.fieldsMeta) {\n      try {\n        const metaData = JSON.parse(this.question.fieldsMeta);\n        const fileConfig = metaData[0];  // Get first config object\n        if (fileConfig) {\n          this.allowedFileTypes = fileConfig.allowedTypes || [];\n          this.maxFileSize = fileConfig.maxFileSize || 0;\n          this.maxFiles = fileConfig.maxFiles || 5;\n        }\n      } catch (error) {\n        console.error('Error parsing fieldsMeta:', error);\n      }\n    }\n  }\n\n  uploadMultipleFiles(event: any) {\n    console.log('File uploader initiated');\n    this.validationErrors = []; // RS 17JAN2025 Clear previous errors\n    let inputFiles: any[] = this.copyOfInputAllFiles ? this.copyOfInputAllFiles : [];\n    const selectedFileData = [];\n    const uploadedFiles = event.target.files;\n\n    // RS 09JAN2025 Check file count limit\n    if (uploadedFiles.length + inputFiles.length > this.maxFiles) {\n      this.validationErrors.push(`Maximum ${this.maxFiles} files allowed`);\n      event.target.value = '';\n      return;\n    }\n\n    const readFilesPromises = [];\n\n    for (const eachUploadedFile of uploadedFiles) {\n      const file: File = eachUploadedFile;\n      \n      //RS 09JAN2025 Check file type\n      const fileExt = '.' + file.name.split('.').pop().toLowerCase();\n      if (this.allowedFileTypes.length > 0 && !this.allowedFileTypes.includes(fileExt)) {\n        this.validationErrors.push(`File type ${fileExt} not allowed. Allowed types: ${this.allowedFileTypes.join(', ')}`);\n        continue;\n      }\n\n      //RS 09JAN2025 Check file size\n      if (this.maxFileSize > 0 && file.size > this.maxFileSize) {\n        this.validationErrors.push(`File \"${file.name}\" exceeds size limit of ${this.maxFileSize / 1048576}MB`);\n        continue;\n      }\n\n      if (!this.validationErrors.length) {\n        const format = fileExt.substring(1);\n        const fileReadPromise = new Promise<void>((resolve, reject) => {\n          const reader = new FileReader();\n          reader.readAsDataURL(file);\n  \n          reader.onload = () => {\n            const fileData = {\n              doc: reader.result,\n              name: file.name,\n              type: file.type,\n              format,\n              size: file.size, // RS 17JAN2025 \n              id: null,\n            };\n  \n            selectedFileData.push(fileData);\n            inputFiles.push(fileData);\n            resolve();\n          };\n  \n          reader.onerror = () => {\n            reject();\n            this.validationErrors.push(`Error reading file \"${file.name}\"`);// RS 17JAN2025 \n          };\n        });\n        readFilesPromises.push(fileReadPromise);     \n    }\n  }\n    if (readFilesPromises.length > 0) {\n      // Wait for all promises to resolve\n      Promise.all(readFilesPromises).then(() => {\n        this.copyOfInputAllFiles = inputFiles;\n        console.log('uploadedFiles', inputFiles);\n        this.selectedFileData.emit(inputFiles);\n      }).catch(() => {\n        console.error('Error reading files');\n      });\n    } else {\n      console.warn('You can upload max 5 files');\n      // this.toastr.warning(TOASTER_MESSAGES.MAX_FIVE_FILES, TOASTER_MESSAGES.WARNING_TITLE);\n    }\n  \n    event.target.value = '';\n  }\n  \n\n  // uploadMultipleFiles(event: any) {\n  //   console.log('File uploader initiated');\n  //   let inputFiles: any[] = this.copyOfInputAllFiles ? this.copyOfInputAllFiles : [];\n  //   const selectedFileData = [];\n  //   const uploadedFiles = event.target.files;\n  //   if (uploadedFiles.length + inputFiles.length <= this.copyOfFileUploadingLimit) {\n  //     for (const eachUploadedFile of uploadedFiles) {\n  //       const reader = new FileReader();\n  //       const file: File = eachUploadedFile;\n  //       const format = file.name.split('.')[1];\n  //       reader.readAsDataURL(file);\n  //       reader.onload = () => {\n  //         selectedFileData.push({\n  //           doc: reader.result,\n  //           name: file.name,\n  //           type: file.type,\n  //           format,\n  //           id: null,\n  //         });\n  //         inputFiles.push({\n  //           doc: reader.result,\n  //           name: file.name,\n  //           type: file.type,\n  //           format,\n  //           id: null,\n  //         });\n  //       };\n  //     }\n  //   } else {\n  //     console.warn('You can upload max 5 files');\n  //     //this.toastr.warning(TOASTER_MESSAGES.MAX_FIVE_FILES, TOASTER_MESSAGES.WARNING_TITLE);\n  //   }\n  //   event.target.value = '';\n  //   this.copyOfInputAllFiles = inputFiles;\n  //   console.log('uploadedFiles',inputFiles);\n  //   this.selectedFileData.emit(inputFiles);\n  // }\n\n\n  deleteFile(currentFileIndex) {\n        const deletedFileName = this.selectedFileNameArray.splice(currentFileIndex, 1);\n        const deletedFile = this.copyOfInputAllFiles.splice(currentFileIndex, 1);\n        console.log('emit', deletedFile[0]);\n        this.deletedFileData.emit(deletedFile[0]);\n        this.selectedFileData.emit(this.copyOfInputAllFiles);\n  }\n\n\n// VD 20May24 - preview changes\n// RS 09DEC24 Changed keys\n  viewFile(currentFile) {\n    this.currentFile = currentFile;\n    this.showFile = true;\n    console.log(currentFile);\n    if(this.question.subText != undefined) {\n      let fileMeta = JSON.parse(this.question.subText);\n      let endpoint = fileMeta.endpoint;\n      let queryParameter = fileMeta.queryParameter;\n        let file = currentFile;\n          if(endpoint){\n            const fullEndPoint = endpoint + '?'+ queryParameter + '=' + file[queryParameter];\n            if(fullEndPoint){\n              this.dataService.apiResponse(fullEndPoint).subscribe((apiResponse) => {\n                if(apiResponse){\n                  this.handleFileContent(apiResponse);\n                }\n              })\n         }\n       }\n    }else {\n        this.viewLocalFile()\n    }\n  }\n\n// // VD 03Aug24 process local preview \n  viewLocalFile(){\n    if(this.currentFile){\n      this.setFileUrl(this.currentFile?.doc);\n      this.fileName = this.currentFile.name;\n      this.isImage = this.currentFile.type.startsWith('image/');\n    }\n\n  }\n\n \n  handleFileContent(fileResponse: any) {\n    const byteArray = new Uint8Array(fileResponse.content.data);\n    const blob = new Blob([byteArray], { type: fileResponse.type });\n    const url = window.URL.createObjectURL(blob);\n    this.setFileUrl(url);\n    this.isImage = false;\n    if(fileResponse.name){\n      this.fileName = fileResponse.name;\n      const imageExtensions = ['jpg', 'jpeg', 'png', 'gif', 'bmp', 'webp'];\n      const fileExtension = fileResponse.name.split('.').pop()?.toLowerCase();\n      this.isImage = imageExtensions.includes(fileExtension || '');\n    }\n  }\n\n  setFileUrl(url: string) {\n    this.fileUrl = this.sanitizer.bypassSecurityTrustResourceUrl(url);\n  }\n\n  getDocIcon(docName) {\n    const ext = docName.split('.').pop(-1);\n    return this.SharedService.docIcon(ext);\n  }\n\n  close(){\n    this.showFile = false;\n    this.fileName = '';\n    this.fileUrl = '';\n    this.isImage = false;\n    if (this.fileUrl) {\n      URL.revokeObjectURL(this.fileUrl);\n    }\n  }\n\n}\n","<div class=\"row\" style=\"margin: 0;\">\n  <div class=\"col-md-12\" *ngIf=\"!isDeleteFileButtonVisible\" style=\"text-align: left;\">\n    <!-- HA 19DEC23 For translation -->\n    <label class=\"she-label\">{{ 'attachment' | i18n:i18nService.currentLanguage }}</label>\n  </div>\n\n  <div class=\"col-lg-5 document-cnt m-t-10 m-b-10\"\n    *ngFor=\"let eachFile of copyOfInputAllFiles; let currentFileIndex = index\">\n     <div *ngIf=\"!tableFile\"> <!-- (click)=\"viewFile(eachFile)\"  -->\n      <div class=\"col-lg-3 document_image\">\n        <img [src]=\"getDocIcon(eachFile?.name)\">\n    </div>\n      <div class=\"col-lg-9 document_name\">\n        {{eachFile?.name}}\n      </div>\n      <div class=\"document_delete\" (click)=\"deleteFile(currentFileIndex);$event.stopPropagation()\" *ngIf=\"isDeleteFileButtonVisible\">\n        <img src=\"https://rnxt.s3.amazonaws.com/Icons/fileTypeIcons/bin.svg\">\n      </div>\n      <!-- VD 20May24 - preview changes-->\n      <div class=\"preview-icon\" (click)=\"viewFile(eachFile)\" *ngIf=\"isDeleteFileButtonVisible\">\n        <img src=\"https://rnxt.s3.amazonaws.com/Icons/fileTypeIcons/icons8-eye-24.png\">\n      </div>\n    </div>\n    <div *ngIf=\"tableFile\" class=\"row\" style=\"cursor: pointer;\">\n      <div class=\"col-lg-3 document_image\">\n          <img [src]=\"getDocIcon(eachFile?.doc)\" style=\"margin-right: 10px;height: 40px;\">\n      </div>\n      <div class=\"col-lg-9 document_name\" style=\"overflow:hidden;height:35px;\">\n          {{eachFile?.name}}\n      </div>\n  </div>\n  </div>\n  <div class=\"col-md-12 m-b-30 text-center\" *ngIf=\"copyOfInputAllFiles?.length === 0 && isShowNoFileIcon\">\n    <img src=\"https://rnxt.s3.amazonaws.com/Icons/fileTypeIcons/ic_no_attachments.svg\" style=\"height: 140px;\">\n  </div>\n</div>\n\n<div class=\"col-lg-6\" style=\"padding:0;margin-top: 10px;\">\n  <label class=\"custom-file\" *ngIf=\"isDeleteFileButtonVisible && !tableFile\">\n    <!-- HA 19DEC23 For translation -->\n    <!-- VD 03May24 file upload fix-->\n    <!-- RS 09JAN2025 -->\n    <button [class]=\"error ? 'she-btn-primary-bordered Invalid' : 'she-btn-primary-bordered'\" style=\"width:275px;\" (click)=\"fileInput.click()\"[ngClass]=\"{ 'btn-disabled': copyOfInputAllFiles?.length >= maxFiles }\" [disabled]=\"copyOfInputAllFiles?.length >= maxFiles\">Choose Files</button>\n    <input #fileInput type=\"file\"  name=\"fileUpload\" multiple=\"multiple\"  [accept]=\"allowedFileTypes.join(',')\"\n    style=\"display:none;\"\n    (change) = uploadMultipleFiles($event)\n    />\n  </label>\n\n  <!-- RS 09JAN2025 -->\n  <!-- Error messages section -->\n  <div class=\"file-constraints\" *ngIf=\"validationErrors.length > 0\">\n    <small class=\"text-danger\">\n      <div *ngFor=\"let error of validationErrors\">{{ error }}</div>\n    </small>\n  </div>\n\n<!-- HA 19DEC23 For translation -->\n  <label *ngIf=\"tableFile\" class=\"btn btn-primary\">\n    {{ 'uploadFile' | i18n:i18nService.currentLanguage }}\n    <input id=\"file\" style=\"display: none;\" type=\"file\" class=\"form-control\" (change)= uploadMultipleFiles($event) />\n  </label>\n  <!-- <span class=\"error-msg\" *ngIf=\"(formControl?.documents?.touched ||        formControl?.documents?.dirty) &&\n  formControl?.documents?.errors?.required\">\n    {{LM_POLICY_VALIDATION_MESSAGE.REQUIRED}}\n  </span> -->\n  <!-- RS 09DEC24 Changed keys--> \n</div>\n<div *ngIf=\"error\" class=\"error-msg\" style=\"margin-top: 10px;\">{{question?.errorMessage}}</div>\n<div class=\"nxt-file-overlay\" *ngIf=\"showFile\">\n  <div class=\"nxt-file-map-modal\">\n    <div class=\"nxt-file-model-content\">\n      <div class=\"nxt-file-model-header\">\n        <h4>{{fileName}}</h4>\n        <button class=\"close-button\" (click)=\"close()\">X</button>\n      </div>\n      <ng-container *ngIf=\"isImage; else otherFile\">\n        <img [src]=\"fileUrl\" class=\"img-fluid\" alt=\"File Preview\" />\n      </ng-container>\n      <ng-template #otherFile>\n        <iframe [src]=\"fileUrl\" width=\"100%\" height=\"500px\"></iframe>\n      </ng-template>\n    </div>\n  </div>\n</div>\n\n\n"]}
|
|
280
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/file-upload/file-upload.component.ts","../../../../../../projects/nxt-app/src/lib/components/file-upload/file-upload.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAS,MAAM,EAAC,YAAY,EAAE,KAAK,EAAsC,MAAM,eAAe,CAAC;;;;;;;;AAWjH,MAAM,OAAO,mBAAmB;IAyBV;IAAuC;IAAiC;IACnF;IAzBC,gBAAgB,GAAG,IAAI,YAAY,EAAS,CAAC;IAC7C,eAAe,GAAG,IAAI,YAAY,EAAO,CAAC;IAC3C,QAAQ,CAAC;IACT,kBAAkB,CAAC;IACnB,yBAAyB,CAAC;IAC1B,gBAAgB,CAAC;IACjB,SAAS,CAAC,CAAE,yBAAyB;IACrC,QAAQ,CAAC;IACT,KAAK,CAAK;IACrB,cAAc;IACL,gBAAgB,GAAa,EAAE,CAAC;IAChC,WAAW,GAAW,CAAC,CAAC,CAAE,mBAAmB;IAC7C,QAAQ,GAAW,CAAC,CAAC,CAAK,gBAAgB;IAC1C,gBAAgB,GAAa,EAAE,CAAC;IAGhC,qBAAqB,GAAa,EAAE,CAAC;IACrC,mBAAmB,CAAC;IACpB,wBAAwB,CAAC;IACzB,OAAO,CAAC;IACR,QAAQ,GAAG,KAAK,CAAC;IACjB,OAAO,GAAG,KAAK,CAAC;IAChB,QAAQ,GAAG,EAAE,CAAC;IACrB,WAAW,CAAM;IACjB,YAAoB,aAA4B,EAAW,WAAwB,EAAS,SAAuB,EAC1G,WAAwB;QADb,kBAAa,GAAb,aAAa,CAAe;QAAW,gBAAW,GAAX,WAAW,CAAa;QAAS,cAAS,GAAT,SAAS,CAAc;QAC1G,gBAAW,GAAX,WAAW,CAAa;IAC7B,CAAC;IACL,cAAc;IACd,QAAQ;QACN,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC9B,CAAC;IACF,6BAA6B;IAC7B,6BAA6B;IAC7B,sEAAsE;IACtE,mBAAmB;IACnB,sBAAsB;IACtB,iCAAiC;IACjC,IAAI;IAEJ,WAAW,CAAC,aAA4B;QACtC,OAAO,CAAC,GAAG,CAAC,gBAAgB,EAAE,aAAa,CAAC,CAAC;QAC7C,IAAI,aAAa,CAAC,QAAQ,EAAE,CAAC,CAAE,WAAW;YACxC,IAAI,CAAC,mBAAmB,GAAG,aAAa,CAAC,QAAQ,CAAC,YAAY,IAAI,EAAE,CAAC;QACvE,CAAC;QAED,IAAI,aAAa,CAAC,kBAAkB,EAAE,CAAC;YACrC,IAAI,CAAC,wBAAwB,GAAG,aAAa,CAAC,kBAAkB,EAAE,YAAY,CAAC;QACjF,CAAC;IAEH,CAAC;IAED,4HAA4H;IAC3H,qBAAqB;QACpB,IAAI,IAAI,CAAC,QAAQ,EAAE,UAAU,EAAE,CAAC;YAC9B,IAAI,CAAC;gBACH,oDAAoD;gBACpD,MAAM,QAAQ,GAAI,OAAO,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,KAAK,QAAQ,CAAE,CAAC,CAAE,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAE,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAE;gBACtJ,MAAM,UAAU,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAE,0BAA0B;gBAC3D,IAAI,UAAU,EAAE,CAAC;oBACf,IAAI,CAAC,gBAAgB,GAAG,UAAU,CAAC,YAAY,IAAI,EAAE,CAAC;oBACtD,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC,WAAW,IAAI,CAAC,CAAC;oBAC/C,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC,QAAQ,IAAI,CAAC,CAAC;gBAC3C,CAAC;YACH,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,OAAO,CAAC,KAAK,CAAC,2BAA2B,EAAE,KAAK,CAAC,CAAC;YACpD,CAAC;QACH,CAAC;IACH,CAAC;IAED,mBAAmB,CAAC,KAAU;QAC5B,OAAO,CAAC,GAAG,CAAC,yBAAyB,CAAC,CAAC;QACvC,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC,CAAC,qCAAqC;QACjE,IAAI,UAAU,GAAU,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE,CAAC;QACjF,MAAM,gBAAgB,GAAG,EAAE,CAAC;QAC5B,MAAM,aAAa,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QAEzC,sCAAsC;QACtC,IAAI,aAAa,CAAC,MAAM,GAAG,UAAU,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;YAC7D,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,QAAQ,gBAAgB,CAAC,CAAC;YACrE,KAAK,CAAC,MAAM,CAAC,KAAK,GAAG,EAAE,CAAC;YACxB,OAAO;QACT,CAAC;QAED,MAAM,iBAAiB,GAAG,EAAE,CAAC;QAE7B,KAAK,MAAM,gBAAgB,IAAI,aAAa,EAAE,CAAC;YAC7C,MAAM,IAAI,GAAS,gBAAgB,CAAC;YAEpC,8BAA8B;YAC9B,MAAM,OAAO,GAAG,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC;YAC/D,IAAI,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;gBACjF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,aAAa,OAAO,gCAAgC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBACnH,SAAS;YACX,CAAC;YAED,8BAA8B;YAC9B,IAAI,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;gBACzD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,2BAA2B,IAAI,CAAC,WAAW,GAAG,OAAO,IAAI,CAAC,CAAC;gBACxG,SAAS;YACX,CAAC;YAED,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC;gBAClC,MAAM,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;gBACpC,MAAM,eAAe,GAAG,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;oBAC5D,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;oBAChC,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;oBAE3B,MAAM,CAAC,MAAM,GAAG,GAAG,EAAE;wBACnB,MAAM,QAAQ,GAAG;4BACf,GAAG,EAAE,MAAM,CAAC,MAAM;4BAClB,IAAI,EAAE,IAAI,CAAC,IAAI;4BACf,IAAI,EAAE,IAAI,CAAC,IAAI;4BACf,MAAM;4BACN,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,gBAAgB;4BACjC,EAAE,EAAE,IAAI;yBACT,CAAC;wBAEF,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;wBAChC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;wBAC1B,OAAO,EAAE,CAAC;oBACZ,CAAC,CAAC;oBAEF,MAAM,CAAC,OAAO,GAAG,GAAG,EAAE;wBACpB,MAAM,EAAE,CAAC;wBACT,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,uBAAuB,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,CAAA,gBAAgB;oBAClF,CAAC,CAAC;gBACJ,CAAC,CAAC,CAAC;gBACH,iBAAiB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YAC5C,CAAC;QACH,CAAC;QACC,IAAI,iBAAiB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACjC,mCAAmC;YACnC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE;gBACvC,IAAI,CAAC,mBAAmB,GAAG,UAAU,CAAC;gBACtC,OAAO,CAAC,GAAG,CAAC,eAAe,EAAE,UAAU,CAAC,CAAC;gBACzC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACzC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE;gBACZ,OAAO,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC;YACvC,CAAC,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;YAC3C,wFAAwF;QAC1F,CAAC;QAED,KAAK,CAAC,MAAM,CAAC,KAAK,GAAG,EAAE,CAAC;IAC1B,CAAC;IAGD,oCAAoC;IACpC,4CAA4C;IAC5C,sFAAsF;IACtF,iCAAiC;IACjC,8CAA8C;IAC9C,qFAAqF;IACrF,sDAAsD;IACtD,yCAAyC;IACzC,6CAA6C;IAC7C,gDAAgD;IAChD,oCAAoC;IACpC,gCAAgC;IAChC,kCAAkC;IAClC,gCAAgC;IAChC,6BAA6B;IAC7B,6BAA6B;IAC7B,oBAAoB;IACpB,sBAAsB;IACtB,cAAc;IACd,4BAA4B;IAC5B,gCAAgC;IAChC,6BAA6B;IAC7B,6BAA6B;IAC7B,oBAAoB;IACpB,sBAAsB;IACtB,cAAc;IACd,WAAW;IACX,QAAQ;IACR,aAAa;IACb,kDAAkD;IAClD,8FAA8F;IAC9F,MAAM;IACN,6BAA6B;IAC7B,2CAA2C;IAC3C,6CAA6C;IAC7C,4CAA4C;IAC5C,IAAI;IAGJ,UAAU,CAAC,gBAAgB;QACrB,MAAM,eAAe,GAAG,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC;QAC/E,MAAM,WAAW,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC;QACzE,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QACpC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QAC1C,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;IAC3D,CAAC;IAGH,+BAA+B;IAC/B,0BAA0B;IACxB,QAAQ,CAAC,WAAW;QAClB,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;QACzB,IAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,IAAI,SAAS,EAAE,CAAC;YACtC,IAAI,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;YACjD,IAAI,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC;YACjC,IAAI,cAAc,GAAG,QAAQ,CAAC,cAAc,CAAC;YAC3C,IAAI,IAAI,GAAG,WAAW,CAAC;YACrB,IAAG,QAAQ,EAAC,CAAC;gBACX,MAAM,YAAY,GAAG,QAAQ,GAAG,GAAG,GAAE,cAAc,GAAG,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC;gBACjF,IAAG,YAAY,EAAC,CAAC;oBACf,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,EAAE;wBACnE,IAAG,WAAW,EAAC,CAAC;4BACd,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;wBACtC,CAAC;oBACH,CAAC,CAAC,CAAA;gBACP,CAAC;YACH,CAAC;QACJ,CAAC;aAAK,CAAC;YACH,IAAI,CAAC,aAAa,EAAE,CAAA;QACxB,CAAC;IACH,CAAC;IAEH,uCAAuC;IACrC,aAAa;QACX,IAAG,IAAI,CAAC,WAAW,EAAC,CAAC;YACnB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC;YACvC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;YACtC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;QAC5D,CAAC;IAEH,CAAC;IAGD,iBAAiB,CAAC,YAAiB;QACjC,MAAM,SAAS,GAAG,IAAI,UAAU,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC5D,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC,SAAS,CAAC,EAAE,EAAE,IAAI,EAAE,YAAY,CAAC,IAAI,EAAE,CAAC,CAAC;QAChE,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QAC7C,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAG,YAAY,CAAC,IAAI,EAAC,CAAC;YACpB,IAAI,CAAC,QAAQ,GAAG,YAAY,CAAC,IAAI,CAAC;YAClC,MAAM,eAAe,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;YACrE,MAAM,aAAa,GAAG,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,WAAW,EAAE,CAAC;YACxE,IAAI,CAAC,OAAO,GAAG,eAAe,CAAC,QAAQ,CAAC,aAAa,IAAI,EAAE,CAAC,CAAC;QAC/D,CAAC;IACH,CAAC;IAED,UAAU,CAAC,GAAW;QACpB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,GAAG,CAAC,CAAC;IACpE,CAAC;IAED,UAAU,CAAC,OAAO;QAChB,MAAM,GAAG,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QACvC,OAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IACzC,CAAC;IAED,KAAK;QACH,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;QACnB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;QAClB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACpC,CAAC;IACH,CAAC;wGAzQU,mBAAmB;4FAAnB,mBAAmB,2YCXhC,6iIAuFA;;4FD5Ea,mBAAmB;kBAL/B,SAAS;+BACE,iBAAiB;iKAKjB,gBAAgB;sBAAzB,MAAM;gBACG,eAAe;sBAAxB,MAAM;gBACE,QAAQ;sBAAhB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,yBAAyB;sBAAjC,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,KAAK;sBAAb,KAAK","sourcesContent":["import { Component, OnInit,Output,EventEmitter, Input ,ElementRef, OnChanges,SimpleChanges} from '@angular/core';\n// HA 19DEC23 imported translation service\nimport { I18nService } from '../../i18n.service';\nimport { SharedService } from '../../services/shared.service';\nimport { DataService } from '../../services/data.service';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\n@Component({\n  selector: 'app-file-upload',\n  templateUrl: './file-upload.component.html',\n  styleUrls: ['./file-upload.component.css']\n})\nexport class FileUploadComponent implements OnInit,OnChanges {\n  @Output() selectedFileData = new EventEmitter<any[]>();\n  @Output() deletedFileData = new EventEmitter<any>();\n  @Input() allFiles;\n  @Input() limitFileUploading;\n  @Input() isDeleteFileButtonVisible;\n  @Input() isShowNoFileIcon;\n  @Input() tableFile;  // file Upload from table\n  @Input() question;\n  @Input() error:any;\n//RS 09JAN2025\n  public allowedFileTypes: string[] = [];\n  public maxFileSize: number = 0;  // in bytes(Binary)\n  public maxFiles: number = 4;     // default limit\n  public validationErrors: string[] = [];\n \n\n  public selectedFileNameArray: string[] = [];\n  public copyOfInputAllFiles;\n  public copyOfFileUploadingLimit;\n  public fileUrl;\n  public showFile = false;\n  public isImage = false;\n  public fileName = '';\n  currentFile: any;\n  constructor(private SharedService: SharedService,  private dataService: DataService,private sanitizer: DomSanitizer,\n    public i18nService: I18nService\n  ) { }\n  //RS 09JAN2025\n  ngOnInit() {\n    this.initializeFileConfigs();\n   }\n  // VD 03May24 file upload fix\n  // onFileUpload(event: any) {\n  //   const fileUploaderElement: HTMLElement = document.getElementById(\n  //     'fileUpload'\n  //   ) as HTMLElement;\n  //   fileUploaderElement.click();\n  // }\n\n  ngOnChanges(simpleChanges: SimpleChanges) {\n    console.log('simple changes', simpleChanges);\n    if (simpleChanges.allFiles) {  //SKS5NOV25\n      this.copyOfInputAllFiles = simpleChanges.allFiles.currentValue || [];\n    }\n\n    if (simpleChanges.limitFileUploading) {\n      this.copyOfFileUploadingLimit = simpleChanges.limitFileUploading?.currentValue;\n    }\n\n  }\n\n  //RS 09JAN2025 Initializes file upload settings (allowed types, max size, and max files) by parsing metadata from fieldsMeta\n   initializeFileConfigs() {\n    if (this.question?.fieldsMeta) {\n      try {\n        // SKS20MAR25 check if question fieldsmeta is string\n        const metaData =  typeof this.question['fieldsMeta'] === 'object'  ?  this.question['fieldsMeta'] || [{}] : JSON.parse( this.question['fieldsMeta']) ;\n        const fileConfig = metaData[0];  // Get first config object\n        if (fileConfig) {\n          this.allowedFileTypes = fileConfig.allowedTypes || [];\n          this.maxFileSize = fileConfig.maxFileSize || 0;\n          this.maxFiles = fileConfig.maxFiles || 5;\n        }\n      } catch (error) {\n        console.error('Error parsing fieldsMeta:', error);\n      }\n    }\n  }\n\n  uploadMultipleFiles(event: any) {\n    console.log('File uploader initiated');\n    this.validationErrors = []; // RS 17JAN2025 Clear previous errors\n    let inputFiles: any[] = this.copyOfInputAllFiles ? this.copyOfInputAllFiles : [];\n    const selectedFileData = [];\n    const uploadedFiles = event.target.files;\n\n    // RS 09JAN2025 Check file count limit\n    if (uploadedFiles.length + inputFiles.length > this.maxFiles) {\n      this.validationErrors.push(`Maximum ${this.maxFiles} files allowed`);\n      event.target.value = '';\n      return;\n    }\n\n    const readFilesPromises = [];\n\n    for (const eachUploadedFile of uploadedFiles) {\n      const file: File = eachUploadedFile;\n      \n      //RS 09JAN2025 Check file type\n      const fileExt = '.' + file.name.split('.').pop().toLowerCase();\n      if (this.allowedFileTypes.length > 0 && !this.allowedFileTypes.includes(fileExt)) {\n        this.validationErrors.push(`File type ${fileExt} not allowed. Allowed types: ${this.allowedFileTypes.join(', ')}`);\n        continue;\n      }\n\n      //RS 09JAN2025 Check file size\n      if (this.maxFileSize > 0 && file.size > this.maxFileSize) {\n        this.validationErrors.push(`File \"${file.name}\" exceeds size limit of ${this.maxFileSize / 1048576}MB`);\n        continue;\n      }\n\n      if (!this.validationErrors.length) {\n        const format = fileExt.substring(1);\n        const fileReadPromise = new Promise<void>((resolve, reject) => {\n          const reader = new FileReader();\n          reader.readAsDataURL(file);\n  \n          reader.onload = () => {\n            const fileData = {\n              doc: reader.result,\n              name: file.name,\n              type: file.type,\n              format,\n              size: file.size, // RS 17JAN2025 \n              id: null,\n            };\n  \n            selectedFileData.push(fileData);\n            inputFiles.push(fileData);\n            resolve();\n          };\n  \n          reader.onerror = () => {\n            reject();\n            this.validationErrors.push(`Error reading file \"${file.name}\"`);// RS 17JAN2025 \n          };\n        });\n        readFilesPromises.push(fileReadPromise);     \n    }\n  }\n    if (readFilesPromises.length > 0) {\n      // Wait for all promises to resolve\n      Promise.all(readFilesPromises).then(() => {\n        this.copyOfInputAllFiles = inputFiles;\n        console.log('uploadedFiles', inputFiles);\n        this.selectedFileData.emit(inputFiles);\n      }).catch(() => {\n        console.error('Error reading files');\n      });\n    } else {\n      console.warn('You can upload max 5 files');\n      // this.toastr.warning(TOASTER_MESSAGES.MAX_FIVE_FILES, TOASTER_MESSAGES.WARNING_TITLE);\n    }\n  \n    event.target.value = '';\n  }\n  \n\n  // uploadMultipleFiles(event: any) {\n  //   console.log('File uploader initiated');\n  //   let inputFiles: any[] = this.copyOfInputAllFiles ? this.copyOfInputAllFiles : [];\n  //   const selectedFileData = [];\n  //   const uploadedFiles = event.target.files;\n  //   if (uploadedFiles.length + inputFiles.length <= this.copyOfFileUploadingLimit) {\n  //     for (const eachUploadedFile of uploadedFiles) {\n  //       const reader = new FileReader();\n  //       const file: File = eachUploadedFile;\n  //       const format = file.name.split('.')[1];\n  //       reader.readAsDataURL(file);\n  //       reader.onload = () => {\n  //         selectedFileData.push({\n  //           doc: reader.result,\n  //           name: file.name,\n  //           type: file.type,\n  //           format,\n  //           id: null,\n  //         });\n  //         inputFiles.push({\n  //           doc: reader.result,\n  //           name: file.name,\n  //           type: file.type,\n  //           format,\n  //           id: null,\n  //         });\n  //       };\n  //     }\n  //   } else {\n  //     console.warn('You can upload max 5 files');\n  //     //this.toastr.warning(TOASTER_MESSAGES.MAX_FIVE_FILES, TOASTER_MESSAGES.WARNING_TITLE);\n  //   }\n  //   event.target.value = '';\n  //   this.copyOfInputAllFiles = inputFiles;\n  //   console.log('uploadedFiles',inputFiles);\n  //   this.selectedFileData.emit(inputFiles);\n  // }\n\n\n  deleteFile(currentFileIndex) {\n        const deletedFileName = this.selectedFileNameArray.splice(currentFileIndex, 1);\n        const deletedFile = this.copyOfInputAllFiles.splice(currentFileIndex, 1);\n        console.log('emit', deletedFile[0]);\n        this.deletedFileData.emit(deletedFile[0]);\n        this.selectedFileData.emit(this.copyOfInputAllFiles);\n  }\n\n\n// VD 20May24 - preview changes\n// RS 09DEC24 Changed keys\n  viewFile(currentFile) {\n    this.currentFile = currentFile;\n    this.showFile = true;\n    console.log(currentFile);\n    if(this.question.subText != undefined) {\n      let fileMeta = JSON.parse(this.question.subText);\n      let endpoint = fileMeta.endpoint;\n      let queryParameter = fileMeta.queryParameter;\n        let file = currentFile;\n          if(endpoint){\n            const fullEndPoint = endpoint + '?'+ queryParameter + '=' + file[queryParameter];\n            if(fullEndPoint){\n              this.dataService.apiResponse(fullEndPoint).subscribe((apiResponse) => {\n                if(apiResponse){\n                  this.handleFileContent(apiResponse);\n                }\n              })\n         }\n       }\n    }else {\n        this.viewLocalFile()\n    }\n  }\n\n// // VD 03Aug24 process local preview \n  viewLocalFile(){\n    if(this.currentFile){\n      this.setFileUrl(this.currentFile?.doc);\n      this.fileName = this.currentFile.name;\n      this.isImage = this.currentFile.type.startsWith('image/');\n    }\n\n  }\n\n \n  handleFileContent(fileResponse: any) {\n    const byteArray = new Uint8Array(fileResponse.content.data);\n    const blob = new Blob([byteArray], { type: fileResponse.type });\n    const url = window.URL.createObjectURL(blob);\n    this.setFileUrl(url);\n    this.isImage = false;\n    if(fileResponse.name){\n      this.fileName = fileResponse.name;\n      const imageExtensions = ['jpg', 'jpeg', 'png', 'gif', 'bmp', 'webp'];\n      const fileExtension = fileResponse.name.split('.').pop()?.toLowerCase();\n      this.isImage = imageExtensions.includes(fileExtension || '');\n    }\n  }\n\n  setFileUrl(url: string) {\n    this.fileUrl = this.sanitizer.bypassSecurityTrustResourceUrl(url);\n  }\n\n  getDocIcon(docName) {\n    const ext = docName.split('.').pop(-1);\n    return this.SharedService.docIcon(ext);\n  }\n\n  close(){\n    this.showFile = false;\n    this.fileName = '';\n    this.fileUrl = '';\n    this.isImage = false;\n    if (this.fileUrl) {\n      URL.revokeObjectURL(this.fileUrl);\n    }\n  }\n\n}\n","<div class=\"row\" style=\"margin: 0;\">\n  <div class=\"col-md-12\" *ngIf=\"!isDeleteFileButtonVisible\" style=\"text-align: left;\">\n    <!-- HA 19DEC23 For translation -->\n    <label class=\"she-label\">{{ 'attachment' | i18n:i18nService.currentLanguage }}</label>\n  </div>\n\n  <div class=\"col-lg-5 document-cnt m-t-10 m-b-10\"\n    *ngFor=\"let eachFile of copyOfInputAllFiles; let currentFileIndex = index\">\n     <div *ngIf=\"!tableFile\"> <!-- (click)=\"viewFile(eachFile)\"  -->\n      <div class=\"col-lg-3 document_image\">\n        <img [src]=\"getDocIcon(eachFile?.name)\">\n    </div>\n      <div class=\"col-lg-9 document_name\">\n        {{eachFile?.name}}\n      </div>\n      <div class=\"document_delete\" (click)=\"deleteFile(currentFileIndex);$event.stopPropagation()\" *ngIf=\"isDeleteFileButtonVisible\">\n        <img src=\"https://rnxt.s3.amazonaws.com/Icons/fileTypeIcons/bin.svg\">\n      </div>\n      <!-- VD 20May24 - preview changes-->\n      <div class=\"preview-icon\" (click)=\"viewFile(eachFile)\" *ngIf=\"isDeleteFileButtonVisible\">\n        <img src=\"https://rnxt.s3.amazonaws.com/Icons/fileTypeIcons/icons8-eye-24.png\">\n      </div>\n    </div>\n    <div *ngIf=\"tableFile\" class=\"row\" style=\"cursor: pointer;\">\n      <div class=\"col-lg-3 document_image\">\n          <img [src]=\"getDocIcon(eachFile?.doc)\" style=\"margin-right: 10px;height: 40px;\">\n      </div>\n      <div class=\"col-lg-9 document_name\" style=\"overflow:hidden;height:35px;\">\n          {{eachFile?.name}}\n      </div>\n  </div>\n  </div>\n  <div class=\"col-md-12 m-b-30 text-center\" *ngIf=\"copyOfInputAllFiles?.length === 0 && isShowNoFileIcon\">\n    <img src=\"https://rnxt.s3.amazonaws.com/Icons/fileTypeIcons/ic_no_attachments.svg\" style=\"height: 140px;\">\n  </div>\n</div>\n\n<div class=\"col-lg-6\" style=\"padding:0;margin-top: 10px;\">\n  <label class=\"custom-file\" *ngIf=\"isDeleteFileButtonVisible && !tableFile\">\n    <!-- HA 19DEC23 For translation -->\n    <!-- VD 03May24 file upload fix-->\n    <!-- RS 09JAN2025 -->\n    <button [class]=\"error ? 'she-btn-primary-bordered Invalid' : 'she-btn-primary-bordered'\" style=\"width:275px;\" (click)=\"fileInput.click()\"[ngClass]=\"{ 'btn-disabled': copyOfInputAllFiles?.length >= maxFiles }\" [disabled]=\"copyOfInputAllFiles?.length >= maxFiles\">Choose Files</button>\n    <input #fileInput type=\"file\"  name=\"fileUpload\" multiple=\"multiple\"  [accept]=\"allowedFileTypes.join(',')\"\n    style=\"display:none;\"\n    (change) = uploadMultipleFiles($event)\n    />\n  </label>\n\n  <!-- RS 09JAN2025 -->\n  <!-- Error messages section -->\n  <div class=\"file-constraints\" *ngIf=\"validationErrors.length > 0\">\n    <small class=\"text-danger\">\n      <div *ngFor=\"let error of validationErrors\">{{ error }}</div>\n    </small>\n  </div>\n\n<!-- HA 19DEC23 For translation -->\n  <label *ngIf=\"tableFile\" class=\"btn btn-primary\">\n    {{ 'uploadFile' | i18n:i18nService.currentLanguage }}\n    <input id=\"file\" style=\"display: none;\" type=\"file\" class=\"form-control\" (change)= uploadMultipleFiles($event) />\n  </label>\n  <!-- <span class=\"error-msg\" *ngIf=\"(formControl?.documents?.touched ||        formControl?.documents?.dirty) &&\n  formControl?.documents?.errors?.required\">\n    {{LM_POLICY_VALIDATION_MESSAGE.REQUIRED}}\n  </span> -->\n  <!-- RS 09DEC24 Changed keys--> \n</div>\n<div *ngIf=\"error\" class=\"error-msg\" style=\"margin-top: 10px;\">{{question?.errorMessage}}</div>\n<div class=\"nxt-file-overlay\" *ngIf=\"showFile\">\n  <div class=\"nxt-file-map-modal\">\n    <div class=\"nxt-file-model-content\">\n      <div class=\"nxt-file-model-header\">\n        <h4>{{fileName}}</h4>\n        <button class=\"close-button\" (click)=\"close()\">X</button>\n      </div>\n      <ng-container *ngIf=\"isImage; else otherFile\">\n        <img [src]=\"fileUrl\" class=\"img-fluid\" alt=\"File Preview\" />\n      </ng-container>\n      <ng-template #otherFile>\n        <iframe [src]=\"fileUrl\" width=\"100%\" height=\"500px\"></iframe>\n      </ng-template>\n    </div>\n  </div>\n</div>\n\n\n"]}
|
|
@@ -23,7 +23,8 @@ export class TableAppendixComponent {
|
|
|
23
23
|
// RS 09DEC24 Changed keys
|
|
24
24
|
ngOnInit() {
|
|
25
25
|
if (this.question.subText != undefined) {
|
|
26
|
-
|
|
26
|
+
// SKS20MAR25 check if question fieldsmeta is string
|
|
27
|
+
this.tableInfo = typeof this.question['fieldsMeta'] === 'object' ? this.question['fieldsMeta'] || [{}] : JSON.parse(this.question['fieldsMeta']);
|
|
27
28
|
this.tableHeader = this.tableInfo.header;
|
|
28
29
|
this.tableData = this.tableInfo.data;
|
|
29
30
|
this.tableAppendix = this.tableInfo.tableAppendix;
|
|
@@ -120,4 +121,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
120
121
|
}], valueChange: [{
|
|
121
122
|
type: Output
|
|
122
123
|
}] } });
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-appendix.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/table-appendix/table-appendix.component.ts","../../../../../../projects/nxt-app/src/lib/components/table-appendix/table-appendix.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\n// HA 19DEC23 imported translation service\nimport { I18nService } from '../../i18n.service';\nimport { TableWrapper } from '../../model/tableWrapper';\nimport { Question } from '../../wrapper';\n\n@Component({\n  selector: 'app-table-appendix',\n  templateUrl: './table-appendix.component.html',\n  styleUrls: ['./table-appendix.component.css']\n})\nexport class TableAppendixComponent implements OnInit {\n  @Input() question: Question\n  @Output() valueChange: EventEmitter<any> = new EventEmitter<any>();\n\n  tableInfo: TableWrapper;\n  tableHeader: any;\n  tableData: any;\n  addRowColSpan: number;\n  tableAppendix:any;\n  dropDownApi :any;\n  dropDownData:any;\n\n  constructor(public i18nService: I18nService) { }\n  // RS 09DEC24 Changed keys\n  ngOnInit(): void {\n    if(this.question.subText != undefined) {\n      this.tableInfo = JSON.parse(this.question.subText);\n\n      this.tableHeader = this.tableInfo.header;\n      this.tableData = this.tableInfo.data;\n      this.tableAppendix = this.tableInfo.tableAppendix;\n      this.dropDownApi = JSON.stringify(this.tableInfo['dropdownApi']);\n      this.dropDownData = this.tableInfo['dropdownData'];\n      const combinedData = {\n        tableData: this.tableData,\n        tableAppendix: null\n      };\n      if (this.tableAppendix) {\n        combinedData.tableAppendix = this.tableAppendix;\n      }\n      this.valueChange.emit(combinedData);\n\n      if(this.tableData?.addRow) {\n        this.addRowColSpan = this.tableHeader.length - 2;\n      }\n    }\n  }\n\n  addRow(): void {\n    let newItem = JSON.parse(JSON.stringify(this.tableInfo.newRowDefault));\n    const updatedTableData = [...this.tableData, newItem];\n    this.tableData = updatedTableData;\n    this.emitTableDataValue(updatedTableData,this.tableAppendix);\n  }\n\n  updateLabel(rowIndex: number, label: string, value: string): void {\n    this.tableData[rowIndex][label] = value;\n    this.tableData[rowIndex].name = value.replace(/\\s+/g, '').toLowerCase();\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n  \n  updateNumber(item: any, label: string, value: string){\n    item.value[label] = value;\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n\n  updateToggle(item: any, header: string, value: any){\n    let label = header['fieldName'];\n    let toggleValue = header['toggleValue'];\n    if(label == 'test1'){\n      item.value[label][1] = value ? toggleValue[0] : toggleValue[1];\n    }else{\n      item.value[label] = value ? toggleValue[0] : toggleValue[1];\n    }\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n  updateDropDown(item: any, label: string, value: any){\n    item.value[label] = value.valueObj['value'];\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n\n  updateCheckText(item: any, label: string, value: any){\n    item.value[label][0] = value;\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n\n  updateTableAppendix(item: any, label: string, value: any){\n    let toggleValue = item.value[0].toggleValue;\n    if(item.key == 'dropDownData'){\n      item.value[0].value[label] = value.valueObj['empIdName'];\n    }else if(item.key == 'toggleData'){\n      item.value[0].value[label] = value ? toggleValue[0] : toggleValue[1];\n    }else{\n      item.value[0].value[label] = value;\n    }\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n\n  emitTableDataValue(updatedTableData: any[],tableAppendix:any): void {\n    const combinedData = {\n      tableData: updatedTableData,\n      tableAppendix: null\n    };\n    if(tableAppendix){\n      combinedData.tableAppendix = this.tableAppendix;\n    }\n    this.valueChange.emit(combinedData);\n  }\n\n  //This function finds the index of the current test in the list of test keys and returns the key of the previous test. \n  // If the current test is the first one, it returns null, as there is no previous test\n  getPreviousTestKey(item: any, currentTest: string): string {\n    const testKeys = Object.keys(item.value);\n    const currentIndex = testKeys.indexOf(currentTest);\n  \n    if (currentIndex > 0) {\n      return testKeys[currentIndex - 1];\n    }\n\n    return null;\n  }\n\n}\n","<table class=\"table table-striped table-bordered\">\n    <thead class=\"none-border\" *ngIf=\"tableInfo.tableType === 'lockout' && tableInfo.tableHeader\">\n      <th></th>\n      <th>{{ tableInfo.tableHeader }}</th>\n      <th></th>\n    </thead>\n    <thead>\n      <th *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + header.size\">\n        {{ header.label }}\n      </th>\n    </thead>\n    <tbody id=\"safetyMeasuresTableBody\">\n      <tr *ngFor=\"let item of tableData; let i = index\">\n        <td *ngFor=\"let header of tableHeader; let j = index\">\n          <div *ngIf=\"header.type === 'text'\">\n            <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" [placeholder]=\"header.placeholder\" (ngModelChange)=\"tableInfo.tableType != 'lockout' ? updateLabel(i, header.fieldName, item[header.fieldName]) : updateNumber(item, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n          </div>\n          <div *ngIf=\"header.type.includes('number')\">\n            <!-- HA 19DEC23 For translation -->\n            <input type=\"number\" [(ngModel)]=\"item.value[header.fieldName]\" [disabled]=\"item.value[getPreviousTestKey(item, header.fieldName)] === null && tableInfo.tableType != 'lockout'\" (ngModelChange)=\"updateNumber(item, header.fieldName, item.value[header.fieldName])\" placeholder=\"{{ 'enterValue' | i18n:i18nService.currentLanguage }}\" class=\"she-line-input table-input\">\n          </div>\n          <div *ngIf=\"header.type === 'dropdown'\">\n            <app-custom-dropdown [fromShengel]=\"true\" [options]=\"dropDownData\" \n            [selectedValue]=\"item.value[header.fieldName]\" [placeholder]=\"header.placeholder\"\n            (valueChange)=\"updateDropDown(item,header.fieldName,$event)\">\n            </app-custom-dropdown>\n          </div>\n          <div *ngIf=\"header.type === 'textcheckbox'\">\n            <div style=\"display: flex; justify-content: center;align-items: center;\">\n              <input type=\"text\" [(ngModel)]=\"item.value[header.fieldName][0]\" (ngModelChange)=\"updateCheckText(item, header.fieldName, item.value[header.fieldName][0])\"  style=\"width: 85px; height: 27px; text-align: center; padding: 5px; border-bottom: none; border-top: 1px solid transparent; border-right: 1px solid transparent; border-left: 1px solid transparent; background: transparent;outline: none;\">\n              <label class=\"switch2\">\n                <input  class=\"switch-input2\" (change)=\"updateToggle(item,header,$event.target.checked)\" \n                type=\"checkbox\"\n                [checked]=\"item.value[header.fieldName][1] == header.toggleValue[0]\"/>\n                <span class=\"switch-label2\" data-on=\"Psi\" data-off=\"Bar\"></span> \n                <span class=\"switch-handle2\"></span> \n              </label> \n            </div>\n          </div>\n          <div *ngIf=\"header.type === 'labelcheckbox'\">\n            <div style=\"display: flex; justify-content: center;align-items: center;\">\n              <!-- HA 19DEC23 For translation -->\n              <span style=\"text-align:left;\">{{ 'calibrated' | i18n:i18nService.currentLanguage }}</span>\n              <label class=\"switch2\">\n                <input  class=\"switch-input2\" (change)=\"updateToggle(item,header,$event.target.checked)\" \n                type=\"checkbox\"\n                [checked]=\"item.value[header.fieldName] == header.toggleValue[0]\"/>\n                <span class=\"switch-label3\" data-on=\"Yes\" data-off=\"No\"></span> \n                <span class=\"switch-handle2\"></span> \n              </label> \n            </div>\n          </div>\n        </td>\n      </tr>\n      <tr *ngIf=\"tableInfo.addRow && tableInfo.tableType === 'lockout'\">\n        <td colspan=\"1\">\n          <!-- HA 19DEC23 For translation -->\n          <b style=\"text-align: center; cursor: pointer;\" id=\"addSafety\"  (click)=\"addRow()\">{{ 'addMore' | i18n:i18nService.currentLanguage }} +</b>\n        </td>\n      </tr>\n      <tr *ngIf=\"tableInfo.addRow && tableInfo.tableType != 'lockout'\">\n        <td colspan=\"3\">\n          <!-- HA 19DEC23 For translation -->\n          <b>{{ 'addMore' | i18n:i18nService.currentLanguage }}</b>\n        </td>\n        <td colspan=\"2\" style=\"text-align: center; cursor: pointer;\" id=\"addSafety\"  (click)=\"addRow()\">\n          +\n        </td>\n      </tr>\n      <tr  *ngFor=\"let item of tableAppendix | keyvalue; let k = index\">\n        <td *ngFor=\"let header of tableHeader; let l = index\">\n          <div *ngIf=\"header.type === 'text'\" >\n            <input type=\"text\" [(ngModel)]=\"item.value[0][header.fieldName]\" (ngModelChange)=\"updateLabel(k, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n          </div>\n          <div *ngIf=\"header.type.includes('dropdown') && item.key == 'dropDownData'\" >\n            <!-- HA 19DEC23 For translation -->\n            <app-custom-dropdown [fromShengel]=\"true\" [apiMeta]=\"dropDownApi\" \n            [selectedValue]=\"item.value[0].value[header.fieldName]\" placeholder=\"---{{'select' | i18n:i18nService.currentLanguage}}---\"\n            (valueChange)=\"updateTableAppendix(item,header.fieldName,$event)\">\n            </app-custom-dropdown>\n          </div>\n          <div *ngIf=\"header.type.includes('datetime') && item.key == 'dateData'\">\n            <input [(ngModel)]=\"item.value[0].value[header.fieldName]\" type=\"datetime-local\"\n            (ngModelChange)=\"updateTableAppendix(item,header.fieldName,$event)\"\n            placeholder=\"DD/MM/YYYY HH:MM\">\n          </div>\n          <div *ngIf=\"header.type.includes('checkbox') && item.key == 'toggleData'\">\n            <label class=\"switch2\">\n              <input  class=\"switch-input2\" (change)=\"updateTableAppendix(item,header.fieldName,$event.target.checked)\" \n              type=\"checkbox\"\n              [checked]=\"item.value[0].value[header.fieldName] == item.value[0].toggleValue[0]\"/>\n              <span class=\"switch-label3\" data-on=\"Safe\" data-off=\"Unsafe\"></span> \n              <span class=\"switch-handle2\"></span> \n            </label> \n          </div>\n          <div *ngIf=\"header.type.includes('file') && item.key == 'fileData'\">\n            <app-file-upload [limitFileUploading]=\"2\" [allFiles]=\"item.value[0].value[header.fieldName]\" [tableFile]=\"true\"\n            (selectedFileData)=\"updateTableAppendix(item ,header.fieldName, $event)\"\n            [isDeleteFileButtonVisible]=\"true\"></app-file-upload>\n          </div>\n        </td>\n      </tr>\n    </tbody>\n  </table>"]}
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-appendix.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/table-appendix/table-appendix.component.ts","../../../../../../projects/nxt-app/src/lib/components/table-appendix/table-appendix.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\n// HA 19DEC23 imported translation service\nimport { I18nService } from '../../i18n.service';\nimport { TableWrapper } from '../../model/tableWrapper';\nimport { Question } from '../../wrapper';\n\n@Component({\n  selector: 'app-table-appendix',\n  templateUrl: './table-appendix.component.html',\n  styleUrls: ['./table-appendix.component.css']\n})\nexport class TableAppendixComponent implements OnInit {\n  @Input() question: Question\n  @Output() valueChange: EventEmitter<any> = new EventEmitter<any>();\n\n  tableInfo: TableWrapper;\n  tableHeader: any;\n  tableData: any;\n  addRowColSpan: number;\n  tableAppendix:any;\n  dropDownApi :any;\n  dropDownData:any;\n\n  constructor(public i18nService: I18nService) { }\n  // RS 09DEC24 Changed keys\n  ngOnInit(): void {\n    if(this.question.subText != undefined) {\n      // SKS20MAR25 check if question fieldsmeta is string\n      this.tableInfo =  typeof this.question['fieldsMeta'] === 'object'  ?  this.question['fieldsMeta'] || [{}] : JSON.parse( this.question['fieldsMeta']) ;\n\n      this.tableHeader = this.tableInfo.header;\n      this.tableData = this.tableInfo.data;\n      this.tableAppendix = this.tableInfo.tableAppendix;\n      this.dropDownApi = JSON.stringify(this.tableInfo['dropdownApi']);\n      this.dropDownData = this.tableInfo['dropdownData'];\n      const combinedData = {\n        tableData: this.tableData,\n        tableAppendix: null\n      };\n      if (this.tableAppendix) {\n        combinedData.tableAppendix = this.tableAppendix;\n      }\n      this.valueChange.emit(combinedData);\n\n      if(this.tableData?.addRow) {\n        this.addRowColSpan = this.tableHeader.length - 2;\n      }\n    }\n  }\n\n  addRow(): void {\n    let newItem = JSON.parse(JSON.stringify(this.tableInfo.newRowDefault));\n    const updatedTableData = [...this.tableData, newItem];\n    this.tableData = updatedTableData;\n    this.emitTableDataValue(updatedTableData,this.tableAppendix);\n  }\n\n  updateLabel(rowIndex: number, label: string, value: string): void {\n    this.tableData[rowIndex][label] = value;\n    this.tableData[rowIndex].name = value.replace(/\\s+/g, '').toLowerCase();\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n  \n  updateNumber(item: any, label: string, value: string){\n    item.value[label] = value;\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n\n  updateToggle(item: any, header: string, value: any){\n    let label = header['fieldName'];\n    let toggleValue = header['toggleValue'];\n    if(label == 'test1'){\n      item.value[label][1] = value ? toggleValue[0] : toggleValue[1];\n    }else{\n      item.value[label] = value ? toggleValue[0] : toggleValue[1];\n    }\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n  updateDropDown(item: any, label: string, value: any){\n    item.value[label] = value.valueObj['value'];\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n\n  updateCheckText(item: any, label: string, value: any){\n    item.value[label][0] = value;\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n\n  updateTableAppendix(item: any, label: string, value: any){\n    let toggleValue = item.value[0].toggleValue;\n    if(item.key == 'dropDownData'){\n      item.value[0].value[label] = value.valueObj['empIdName'];\n    }else if(item.key == 'toggleData'){\n      item.value[0].value[label] = value ? toggleValue[0] : toggleValue[1];\n    }else{\n      item.value[0].value[label] = value;\n    }\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n\n  emitTableDataValue(updatedTableData: any[],tableAppendix:any): void {\n    const combinedData = {\n      tableData: updatedTableData,\n      tableAppendix: null\n    };\n    if(tableAppendix){\n      combinedData.tableAppendix = this.tableAppendix;\n    }\n    this.valueChange.emit(combinedData);\n  }\n\n  //This function finds the index of the current test in the list of test keys and returns the key of the previous test. \n  // If the current test is the first one, it returns null, as there is no previous test\n  getPreviousTestKey(item: any, currentTest: string): string {\n    const testKeys = Object.keys(item.value);\n    const currentIndex = testKeys.indexOf(currentTest);\n  \n    if (currentIndex > 0) {\n      return testKeys[currentIndex - 1];\n    }\n\n    return null;\n  }\n\n}\n","<table class=\"table table-striped table-bordered\">\n    <thead class=\"none-border\" *ngIf=\"tableInfo.tableType === 'lockout' && tableInfo.tableHeader\">\n      <th></th>\n      <th>{{ tableInfo.tableHeader }}</th>\n      <th></th>\n    </thead>\n    <thead>\n      <th *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + header.size\">\n        {{ header.label }}\n      </th>\n    </thead>\n    <tbody id=\"safetyMeasuresTableBody\">\n      <tr *ngFor=\"let item of tableData; let i = index\">\n        <td *ngFor=\"let header of tableHeader; let j = index\">\n          <div *ngIf=\"header.type === 'text'\">\n            <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" [placeholder]=\"header.placeholder\" (ngModelChange)=\"tableInfo.tableType != 'lockout' ? updateLabel(i, header.fieldName, item[header.fieldName]) : updateNumber(item, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n          </div>\n          <div *ngIf=\"header.type.includes('number')\">\n            <!-- HA 19DEC23 For translation -->\n            <input type=\"number\" [(ngModel)]=\"item.value[header.fieldName]\" [disabled]=\"item.value[getPreviousTestKey(item, header.fieldName)] === null && tableInfo.tableType != 'lockout'\" (ngModelChange)=\"updateNumber(item, header.fieldName, item.value[header.fieldName])\" placeholder=\"{{ 'enterValue' | i18n:i18nService.currentLanguage }}\" class=\"she-line-input table-input\">\n          </div>\n          <div *ngIf=\"header.type === 'dropdown'\">\n            <app-custom-dropdown [fromShengel]=\"true\" [options]=\"dropDownData\" \n            [selectedValue]=\"item.value[header.fieldName]\" [placeholder]=\"header.placeholder\"\n            (valueChange)=\"updateDropDown(item,header.fieldName,$event)\">\n            </app-custom-dropdown>\n          </div>\n          <div *ngIf=\"header.type === 'textcheckbox'\">\n            <div style=\"display: flex; justify-content: center;align-items: center;\">\n              <input type=\"text\" [(ngModel)]=\"item.value[header.fieldName][0]\" (ngModelChange)=\"updateCheckText(item, header.fieldName, item.value[header.fieldName][0])\"  style=\"width: 85px; height: 27px; text-align: center; padding: 5px; border-bottom: none; border-top: 1px solid transparent; border-right: 1px solid transparent; border-left: 1px solid transparent; background: transparent;outline: none;\">\n              <label class=\"switch2\">\n                <input  class=\"switch-input2\" (change)=\"updateToggle(item,header,$event.target.checked)\" \n                type=\"checkbox\"\n                [checked]=\"item.value[header.fieldName][1] == header.toggleValue[0]\"/>\n                <span class=\"switch-label2\" data-on=\"Psi\" data-off=\"Bar\"></span> \n                <span class=\"switch-handle2\"></span> \n              </label> \n            </div>\n          </div>\n          <div *ngIf=\"header.type === 'labelcheckbox'\">\n            <div style=\"display: flex; justify-content: center;align-items: center;\">\n              <!-- HA 19DEC23 For translation -->\n              <span style=\"text-align:left;\">{{ 'calibrated' | i18n:i18nService.currentLanguage }}</span>\n              <label class=\"switch2\">\n                <input  class=\"switch-input2\" (change)=\"updateToggle(item,header,$event.target.checked)\" \n                type=\"checkbox\"\n                [checked]=\"item.value[header.fieldName] == header.toggleValue[0]\"/>\n                <span class=\"switch-label3\" data-on=\"Yes\" data-off=\"No\"></span> \n                <span class=\"switch-handle2\"></span> \n              </label> \n            </div>\n          </div>\n        </td>\n      </tr>\n      <tr *ngIf=\"tableInfo.addRow && tableInfo.tableType === 'lockout'\">\n        <td colspan=\"1\">\n          <!-- HA 19DEC23 For translation -->\n          <b style=\"text-align: center; cursor: pointer;\" id=\"addSafety\"  (click)=\"addRow()\">{{ 'addMore' | i18n:i18nService.currentLanguage }} +</b>\n        </td>\n      </tr>\n      <tr *ngIf=\"tableInfo.addRow && tableInfo.tableType != 'lockout'\">\n        <td colspan=\"3\">\n          <!-- HA 19DEC23 For translation -->\n          <b>{{ 'addMore' | i18n:i18nService.currentLanguage }}</b>\n        </td>\n        <td colspan=\"2\" style=\"text-align: center; cursor: pointer;\" id=\"addSafety\"  (click)=\"addRow()\">\n          +\n        </td>\n      </tr>\n      <tr  *ngFor=\"let item of tableAppendix | keyvalue; let k = index\">\n        <td *ngFor=\"let header of tableHeader; let l = index\">\n          <div *ngIf=\"header.type === 'text'\" >\n            <input type=\"text\" [(ngModel)]=\"item.value[0][header.fieldName]\" (ngModelChange)=\"updateLabel(k, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n          </div>\n          <div *ngIf=\"header.type.includes('dropdown') && item.key == 'dropDownData'\" >\n            <!-- HA 19DEC23 For translation -->\n            <app-custom-dropdown [fromShengel]=\"true\" [apiMeta]=\"dropDownApi\" \n            [selectedValue]=\"item.value[0].value[header.fieldName]\" placeholder=\"---{{'select' | i18n:i18nService.currentLanguage}}---\"\n            (valueChange)=\"updateTableAppendix(item,header.fieldName,$event)\">\n            </app-custom-dropdown>\n          </div>\n          <div *ngIf=\"header.type.includes('datetime') && item.key == 'dateData'\">\n            <input [(ngModel)]=\"item.value[0].value[header.fieldName]\" type=\"datetime-local\"\n            (ngModelChange)=\"updateTableAppendix(item,header.fieldName,$event)\"\n            placeholder=\"DD/MM/YYYY HH:MM\">\n          </div>\n          <div *ngIf=\"header.type.includes('checkbox') && item.key == 'toggleData'\">\n            <label class=\"switch2\">\n              <input  class=\"switch-input2\" (change)=\"updateTableAppendix(item,header.fieldName,$event.target.checked)\" \n              type=\"checkbox\"\n              [checked]=\"item.value[0].value[header.fieldName] == item.value[0].toggleValue[0]\"/>\n              <span class=\"switch-label3\" data-on=\"Safe\" data-off=\"Unsafe\"></span> \n              <span class=\"switch-handle2\"></span> \n            </label> \n          </div>\n          <div *ngIf=\"header.type.includes('file') && item.key == 'fileData'\">\n            <app-file-upload [limitFileUploading]=\"2\" [allFiles]=\"item.value[0].value[header.fieldName]\" [tableFile]=\"true\"\n            (selectedFileData)=\"updateTableAppendix(item ,header.fieldName, $event)\"\n            [isDeleteFileButtonVisible]=\"true\"></app-file-upload>\n          </div>\n        </td>\n      </tr>\n    </tbody>\n  </table>"]}
|