@piserve-tech/form-submission 1.3.84 → 1.3.85
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.
|
@@ -133,11 +133,12 @@ export class MultipleSubformComponent {
|
|
|
133
133
|
this.updateSubFormWithSubmissions();
|
|
134
134
|
}
|
|
135
135
|
addNewSubmission() {
|
|
136
|
+
const subForm = this.cleanCircularReferences(this.subForm);
|
|
136
137
|
const dialogConfig = new MatDialogConfig();
|
|
137
138
|
dialogConfig.position = { top: '5%' };
|
|
138
139
|
dialogConfig.width = '100%';
|
|
139
140
|
dialogConfig.data = {
|
|
140
|
-
subForm:
|
|
141
|
+
subForm: subForm,
|
|
141
142
|
acceptedLanguage: this.acceptedLanguage
|
|
142
143
|
};
|
|
143
144
|
dialogConfig.hasBackdrop = true;
|
|
@@ -154,6 +155,22 @@ export class MultipleSubformComponent {
|
|
|
154
155
|
}
|
|
155
156
|
});
|
|
156
157
|
}
|
|
158
|
+
cleanCircularReferences(obj, seen = new WeakSet()) {
|
|
159
|
+
if (obj === null || typeof obj !== "object") {
|
|
160
|
+
return obj;
|
|
161
|
+
}
|
|
162
|
+
if (seen.has(obj)) {
|
|
163
|
+
return;
|
|
164
|
+
}
|
|
165
|
+
seen.add(obj);
|
|
166
|
+
const cleanedObj = Array.isArray(obj) ? [] : {};
|
|
167
|
+
for (const key in obj) {
|
|
168
|
+
if (Object.prototype.hasOwnProperty.call(obj, key)) {
|
|
169
|
+
cleanedObj[key] = this.cleanCircularReferences(obj[key], seen);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
return cleanedObj;
|
|
173
|
+
}
|
|
157
174
|
updateSubmission(result, index) {
|
|
158
175
|
const processFormElements = (rows, answers) => {
|
|
159
176
|
rows.forEach((row) => {
|
|
@@ -261,4 +278,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
261
278
|
}], acceptedLanguage: [{
|
|
262
279
|
type: Input
|
|
263
280
|
}] } });
|
|
264
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multiple-subform.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/question/multiple-subform/multiple-subform.component.ts","../../../../../projects/form-submission/src/question/multiple-subform/multiple-subform.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { MatDialog, MatDialogConfig } from '@angular/material/dialog';\nimport { SubmissionModalComponent } from '../../sub-form/submission-modal/submission-modal.component';\nimport { Attachment } from '../../models/attachment.model';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\ninterface Answer {\n  questionId: string;\n  answer?: any;\n  answerId?: string;\n  deleteFiles?: string[];\n  attachments?: Attachment[];\n  files?: any;\n  isChild?: boolean;\n  htmlContent?: SafeHtml;\n}\n\ninterface Submission {\n  submissionId: string;\n  answers: Answer[];\n}\n\n@Component({\n  selector: 'lib-multiple-subform',\n  templateUrl: './multiple-subform.component.html',\n  styleUrls: ['./multiple-subform.component.scss'],\n})\nexport class MultipleSubformComponent {\n  @Input() subForm: any = {};\n  @Output() subFormChange = new EventEmitter<any>();\n  @Input() acceptedLanguage: string ='';\n\n  submissions: Submission[] = [];\n  deletedSubmissions: string[] = [];\n  displayedColumns: string[] = [];\n\n  constructor(public dialog: MatDialog, private sanitizer: DomSanitizer) {}\n\n  ngOnInit() {    \n    if (this.subForm?.submissions) {\n      this.submissions = this.subForm.submissions;\n      this.subForm.deletedSubmissions = [];\n    }\n    this.initializeDisplayedColumns();\n  }\n\n  initializeDisplayedColumns() {\n    this.displayedColumns = this.subForm.rows.flatMap((item: any) => \n      item.grid\n          .map((gridItem: any) => gridItem.element.question)\n  );\n  \n   // this.displayedColumns = this.subForm.formElements.map((fe: any) => fe.element.question);\n    this.displayedColumns.push('actions');\n  }\n\n  getAnswerByQuestionId(submission: Submission, questionId: string) {\n    const answers =  submission.answers.find(answer => answer.questionId === questionId);\n    if(answers) {\n      answers['htmlContent'] = this.sanitizer.bypassSecurityTrustHtml(answers.answer);\n    }\n   \n    return answers;\n  }\n\n  subFormSubmission(subForm: any) {\n    const processFormElements = (rows: any[], isChild: boolean = false): Answer[] => {\n      const answers: Answer[] = [];\n  \n      rows.flatMap((item: any) => \n        item.grid.forEach((formElement: any) => {\n        const answer: Answer = {\n          questionId: formElement.element.id,\n          answer: formElement.element?.answer || '',\n          files: formElement.element.formElement.elementType == 'FILE_PICKER' && formElement.element.answer\n            ? formElement.element.answer\n            : undefined,\n          isChild: isChild\n        };\n  \n        if (\n          formElement.element.formElement.elementType == 'FILE_PICKER' &&\n          formElement.element.answer\n        ) {\n          const fileNames = formElement.element.answer.map(\n            (file: any) => file?._file.name\n          );\n          answer.answer = fileNames;\n        }\n        answers.push(answer);\n  \n        if (formElement.element.childLogics) {\n          formElement.element.childLogics.forEach((logic: any) => {\n            if(logic.showLogic){\n              answers.push(...processFormElements(logic.rows, true));\n              logic.showLogic=false;\n            }\n          });\n        }\n      })\n      );\n      return answers;\n    };\n  \n    const answers = processFormElements(subForm.rows);\n  \n    if (answers.length > 0) {\n      const submission: Submission = {\n        submissionId: '',\n        answers: answers,\n      };\n      this.submissions.push(submission);\n      this.submissions = [...this.submissions];\n      this.updateSubFormWithSubmissions();\n    }\n  }\n  \n\n  editSubFormSubmission(index: number, submission: Submission) {\n    const subForm = this.bindAnswers(this.subForm, submission);\n    const dialogConfig = new MatDialogConfig();\n    dialogConfig.position = { top: '5%' };\n    dialogConfig.width = '100%';\n    dialogConfig.data = {\n      subForm: subForm,\n      acceptedLanguage: this.acceptedLanguage\n    };\n    dialogConfig.hasBackdrop = true;\n    dialogConfig.disableClose = true;\n    dialogConfig.maxHeight = '80vh';\n    const dialogRef = this.dialog.open(SubmissionModalComponent, dialogConfig);\n\n    dialogRef.afterClosed().subscribe((result: any) => {\n      if (result) {\n          this.updateSubmission(result, index);\n        }\n    });\n  }\n\n  bindAnswers(subForm: any, submission: Submission): any {\n    const bindElementAnswers = (rows: any[], answers: Answer[]) => {\n      rows.forEach((row: any) => {\n        row.grid.forEach((grid:any)=>{          \n          const answer = answers.find(\n            (a) => a.questionId === grid.element.id\n          );\n          if (answer) {\n            grid.element.answer =\n            grid.element.formElement.elementType == 'FILE_PICKER'\n                ? answer?.files\n                : answer.answer;\n                grid.element.answerId = answer.answerId;\n                grid.element.attachments = answer.attachments;\n          }\n          if (grid.element.childLogics) {\n            grid.element.childLogics.forEach((logic: any) => {\n              bindElementAnswers(logic.rows, answers);\n            });\n          }\n        })\n        \n      });\n    };\n\n    const updatedSubForm = { ...subForm };    \n    bindElementAnswers(updatedSubForm.rows, submission.answers);\n    return updatedSubForm;\n  }\n\n  deleteSubForm(index: number) {\n    const submission = this.submissions[index];\n    if (submission.submissionId) {\n      this.deletedSubmissions.push(submission.submissionId);\n    }\n    this.submissions.splice(index, 1);\n    this.submissions = [...this.submissions];\n    this.updateSubFormWithSubmissions();\n  }\n\n  addNewSubmission() {\n    const dialogConfig = new MatDialogConfig();\n    dialogConfig.position = { top: '5%' };\n    dialogConfig.width = '100%';\n    dialogConfig.data = {\n      subForm: JSON.parse(JSON.stringify(this.subForm)), \n      acceptedLanguage: this.acceptedLanguage\n    };\n    dialogConfig.hasBackdrop = true;\n    dialogConfig.disableClose = true;\n    dialogConfig.maxHeight = '80vh';\n    const dialogRef = this.dialog.open(SubmissionModalComponent, dialogConfig);\n  \n    dialogRef.afterClosed().subscribe((result: any) => {\n      if (result) {\n        const hasData = result.rows.flatMap((item: any) => \n          item.grid\n              .some((formElement: any) => formElement.element.answer && formElement.element.answer.length > 0)\n      );\n  \n        if (hasData) {\n          this.subFormSubmission(result);\n        }\n      }\n    });\n  }\n  \n  \n\n  updateSubmission(result: any, index: number) {\n    const processFormElements = (rows: any[], answers: Answer[]) => {\n      rows.forEach((row: any) => {\n        row.grid.forEach((grid:any)=>{\n          let answer: Answer = {\n            questionId: grid.element.id,\n            answerId: grid.element?.answerId || '',\n            attachments: grid.element.attachments || [],\n            answer: [],\n            files: [],\n            deleteFiles: [],\n          };\n    \n          if (answer.attachments) {\n            answer.answer = answer.attachments.map(\n              (attachment: Attachment) => attachment.fileName\n            );\n          }\n    \n          if (grid.element.formElement.elementType === 'FILE_PICKER') {\n            if (grid.element?.deleteFiles) {\n              answer.answer = [];\n              grid.element.deleteFiles.forEach((deletedId: string) => {\n                answer.deleteFiles?.push(deletedId);\n                if (answer.attachments) {\n                  answer.attachments = answer.attachments.filter(\n                    (attachment: Attachment) => {\n                      const fileName = attachment.fileName;\n                      if (attachment.fileId !== deletedId) {\n                        if (!answer.answer.includes(fileName)) {\n                          answer.answer.push(fileName);\n                          return true;\n                        }\n                      }\n                      return false;\n                    }\n                  );\n                }\n              });\n            }\n            if (grid.element.answer) {\n              answer.files = grid.element.answer;\n              grid.element.answer.forEach((file: any) => {\n                const fileName = file._file?.name;\n                let fileNamesArray = Array.isArray(answer.answer)\n                  ? answer.answer\n                  : [];\n                if (!fileNamesArray.includes(fileName)) {\n                  fileNamesArray.push(fileName);\n                }\n                answer.answer = fileNamesArray;\n              });\n            }\n          } else {\n            answer = {\n              questionId: grid.element.id,\n              answerId: grid.element?.answerId || '',\n              attachments: grid.element.attachments,\n              answer: grid.element.answer,\n            };\n          }\n          grid.element.answer = '';\n          answers.push(answer);\n    \n          if (grid.element.childLogics) {\n            grid.element.childLogics.forEach((logic: any) => {\n              if(logic.showLogic){\n                processFormElements(logic.rows, answers);\n              }\n            });\n          }\n        })\n      });\n    };\n  \n    this.submissions[index].answers = [];    \n    processFormElements(result.rows, this.submissions[index].answers);\n    this.submissions = [...this.submissions];\n    this.updateSubFormWithSubmissions();\n    this.clearEmptyRows();\n  }  \n\n  updateSubFormWithSubmissions() {\n    this.subForm.submissions = this.submissions;\n    this.subForm.deletedSubmissions = this.deletedSubmissions;\n    this.subFormChange.emit(this.subForm);\n  }\n\n  clearEmptyRows() {\n    const nonEmptySubmissions:Submission[] = [];\n    const emptySubmissionIds:string[] = [];\n  \n    this.submissions.forEach(submission => {\n      if (submission.answers.some(answer => answer.answer !== '')) {\n        nonEmptySubmissions.push(submission);\n      } else if (submission.submissionId) {\n        emptySubmissionIds.push(submission.submissionId);\n      }\n    });\n  \n    this.submissions = nonEmptySubmissions;\n    this.deletedSubmissions.push(...emptySubmissionIds);\n    this.updateSubFormWithSubmissions();\n  }\n  \n}\n","<div class=\"example-container \" tabindex=\"0\">\n  <div class=\"table-container\">\n    <table mat-table [dataSource]=\"submissions\" class=\"mat-elevation-z8\">\n      <ng-container *ngFor=\"let row of subForm.rows\">\n      <ng-container *ngFor=\"let formElement of row.grid\" [matColumnDef]=\"formElement.element.question\">\n        <th mat-header-cell *matHeaderCellDef class=\"border border-1\">{{ formElement.element.question }}</th>\n        <td mat-cell *matCellDef=\"let submission\" class=\"border border-1\" [ngClass]=\"{'hidden': getAnswerByQuestionId(submission, formElement.element.id)?.isChild}\">\n          <div [innerHTML]=\"getAnswerByQuestionId(submission, formElement.element.id)?.htmlContent\"></div>\n        </td>\n      </ng-container>\n    </ng-container>\n      <ng-container matColumnDef=\"actions\" stickyEnd>\n        <th mat-header-cell *matHeaderCellDef  class=\"border border-1\"> Actions </th>\n        <td mat-cell *matCellDef=\"let submission; let i = index\" class=\"text-center border border-1\">\n\n          <div>\n            <button class=\"btn\" mat-icon-button [matMenuTriggerFor]=\"menu\" aria-label=\"Example icon-button with a menu\">\n              <mat-icon>more_vert</mat-icon>\n            </button>\n            <mat-menu #menu=\"matMenu\">\n              <button mat-menu-item  (click)=\"editSubFormSubmission(i, submission)\">\n                <svg width=\"29\" height=\"28\" viewBox=\"0 0 29 28\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                  <rect x=\"0.5\" y=\"0.5\" width=\"28\" height=\"26.4737\" rx=\"5.5\" fill=\"white\" stroke=\"#D8D8D8\"/>\n                  <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12.0009 19.0787H9.1582V16.2361C9.1582 15.9447 9.2739 15.6653 9.47999 15.4593L16.2224 8.71686C16.4284 8.5105 16.708 8.39453 16.9995 8.39453C17.2911 8.39453 17.5707 8.5105 17.7767 8.71686L19.5201 10.4603C19.7264 10.6663 19.8424 10.9458 19.8424 11.2374C19.8424 11.529 19.7264 11.8086 19.5201 12.0145L12.7777 18.757C12.5715 18.9628 12.2922 19.0785 12.0009 19.0787Z\" stroke=\"#084FFF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                  <path d=\"M15.1704 10.3984L17.8415 13.0695\" stroke=\"#084FFF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                </svg>\n              </button>\n              <button mat-menu-item (click)=\"deleteSubForm(i)\">\n                <svg width=\"29\" height=\"28\" viewBox=\"0 0 29 28\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                  <rect x=\"0.5\" y=\"0.5\" width=\"27.6402\" height=\"26.1328\" rx=\"5.5\" fill=\"white\" stroke=\"#D8D8D8\"/>\n                  <path d=\"M8.60449 9.20637H20.0354\" stroke=\"#084FFF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                  <path d=\"M19.2189 9.20703V17.7863C19.2189 18.6482 18.4881 19.3462 17.5859 19.3462H11.0539C10.1517 19.3462 9.4209 18.6482 9.4209 17.7863V9.20703\" stroke=\"#084FFF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                  <path d=\"M16.7696 6.67122H11.8706\" stroke=\"#084FFF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                  <path d=\"M12.6871 12.3242V16.2239\" stroke=\"#084FFF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                  <path d=\"M15.9532 12.3242V16.2239\" stroke=\"#084FFF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                </svg>\n              </button>\n            </mat-menu>\n          </div>\n        </td>\n      </ng-container>\n\n      <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n      <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n    </table>\n  </div>\n  <div class=\"footer\">\n    <div class=\"addNewBtn\" (click)=\"addNewSubmission()\">\n      <svg width=\"15\" height=\"14\" viewBox=\"0 0 15 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12.5556 13.2778H2.44444C1.64639 13.2778 1 12.6673 1 11.9136V2.3642C1 1.61048 1.64639 1 2.44444 1H12.5556C13.3536 1 14 1.61048 14 2.3642V11.9136C14 12.6673 13.3536 13.2778 12.5556 13.2778Z\" stroke=\"#D8D8D8\" stroke-width=\"0.8\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n        <path d=\"M5.3335 7.50347H9.66683\" stroke=\"#084FFF\" stroke-width=\"0.8\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n        <path d=\"M7.50005 5.33594V9.66927\" stroke=\"#084FFF\" stroke-width=\"0.8\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n      </svg>\n      <a class=\"ms-2 text-decoration-none\">Add New</a>\n    </div>\n  </div>\n</div>\n"]}
|
|
281
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multiple-subform.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/question/multiple-subform/multiple-subform.component.ts","../../../../../projects/form-submission/src/question/multiple-subform/multiple-subform.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { MatDialog, MatDialogConfig } from '@angular/material/dialog';\nimport { SubmissionModalComponent } from '../../sub-form/submission-modal/submission-modal.component';\nimport { Attachment } from '../../models/attachment.model';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\ninterface Answer {\n  questionId: string;\n  answer?: any;\n  answerId?: string;\n  deleteFiles?: string[];\n  attachments?: Attachment[];\n  files?: any;\n  isChild?: boolean;\n  htmlContent?: SafeHtml;\n}\n\ninterface Submission {\n  submissionId: string;\n  answers: Answer[];\n}\n\n@Component({\n  selector: 'lib-multiple-subform',\n  templateUrl: './multiple-subform.component.html',\n  styleUrls: ['./multiple-subform.component.scss'],\n})\nexport class MultipleSubformComponent {\n  @Input() subForm: any = {};\n  @Output() subFormChange = new EventEmitter<any>();\n  @Input() acceptedLanguage: string ='';\n\n  submissions: Submission[] = [];\n  deletedSubmissions: string[] = [];\n  displayedColumns: string[] = [];\n\n  constructor(public dialog: MatDialog, private sanitizer: DomSanitizer) {}\n\n  ngOnInit() {    \n    if (this.subForm?.submissions) {\n      this.submissions = this.subForm.submissions;\n      this.subForm.deletedSubmissions = [];\n    }\n    this.initializeDisplayedColumns();\n  }\n\n  initializeDisplayedColumns() {\n    this.displayedColumns = this.subForm.rows.flatMap((item: any) => \n      item.grid\n          .map((gridItem: any) => gridItem.element.question)\n  );\n  \n   // this.displayedColumns = this.subForm.formElements.map((fe: any) => fe.element.question);\n    this.displayedColumns.push('actions');\n  }\n\n  getAnswerByQuestionId(submission: Submission, questionId: string) {\n    const answers =  submission.answers.find(answer => answer.questionId === questionId);\n    if(answers) {\n      answers['htmlContent'] = this.sanitizer.bypassSecurityTrustHtml(answers.answer);\n    }\n   \n    return answers;\n  }\n\n  subFormSubmission(subForm: any) {\n    const processFormElements = (rows: any[], isChild: boolean = false): Answer[] => {\n      const answers: Answer[] = [];\n  \n      rows.flatMap((item: any) => \n        item.grid.forEach((formElement: any) => {\n        const answer: Answer = {\n          questionId: formElement.element.id,\n          answer: formElement.element?.answer || '',\n          files: formElement.element.formElement.elementType == 'FILE_PICKER' && formElement.element.answer\n            ? formElement.element.answer\n            : undefined,\n          isChild: isChild\n        };\n  \n        if (\n          formElement.element.formElement.elementType == 'FILE_PICKER' &&\n          formElement.element.answer\n        ) {\n          const fileNames = formElement.element.answer.map(\n            (file: any) => file?._file.name\n          );\n          answer.answer = fileNames;\n        }\n        answers.push(answer);\n  \n        if (formElement.element.childLogics) {\n          formElement.element.childLogics.forEach((logic: any) => {\n            if(logic.showLogic){\n              answers.push(...processFormElements(logic.rows, true));\n              logic.showLogic=false;\n            }\n          });\n        }\n      })\n      );\n      return answers;\n    };\n  \n    const answers = processFormElements(subForm.rows);\n  \n    if (answers.length > 0) {\n      const submission: Submission = {\n        submissionId: '',\n        answers: answers,\n      };\n      this.submissions.push(submission);\n      this.submissions = [...this.submissions];\n      this.updateSubFormWithSubmissions();\n    }\n  }\n  \n\n  editSubFormSubmission(index: number, submission: Submission) {\n    const subForm = this.bindAnswers(this.subForm, submission);\n    const dialogConfig = new MatDialogConfig();\n    dialogConfig.position = { top: '5%' };\n    dialogConfig.width = '100%';\n    dialogConfig.data = {\n      subForm: subForm,\n      acceptedLanguage: this.acceptedLanguage\n    };\n    dialogConfig.hasBackdrop = true;\n    dialogConfig.disableClose = true;\n    dialogConfig.maxHeight = '80vh';\n    const dialogRef = this.dialog.open(SubmissionModalComponent, dialogConfig);\n\n    dialogRef.afterClosed().subscribe((result: any) => {\n      if (result) {\n          this.updateSubmission(result, index);\n        }\n    });\n  }\n\n  bindAnswers(subForm: any, submission: Submission): any {\n    const bindElementAnswers = (rows: any[], answers: Answer[]) => {\n      rows.forEach((row: any) => {\n        row.grid.forEach((grid:any)=>{          \n          const answer = answers.find(\n            (a) => a.questionId === grid.element.id\n          );\n          if (answer) {\n            grid.element.answer =\n            grid.element.formElement.elementType == 'FILE_PICKER'\n                ? answer?.files\n                : answer.answer;\n                grid.element.answerId = answer.answerId;\n                grid.element.attachments = answer.attachments;\n          }\n          if (grid.element.childLogics) {\n            grid.element.childLogics.forEach((logic: any) => {\n              bindElementAnswers(logic.rows, answers);\n            });\n          }\n        })\n        \n      });\n    };\n\n    const updatedSubForm = { ...subForm };    \n    bindElementAnswers(updatedSubForm.rows, submission.answers);\n    return updatedSubForm;\n  }\n\n  deleteSubForm(index: number) {\n    const submission = this.submissions[index];\n    if (submission.submissionId) {\n      this.deletedSubmissions.push(submission.submissionId);\n    }\n    this.submissions.splice(index, 1);\n    this.submissions = [...this.submissions];\n    this.updateSubFormWithSubmissions();\n  }\n\n  addNewSubmission() {\n    const subForm = this.cleanCircularReferences(this.subForm);\n    const dialogConfig = new MatDialogConfig();\n    dialogConfig.position = { top: '5%' };\n    dialogConfig.width = '100%';\n    dialogConfig.data = {\n      subForm: subForm, \n      acceptedLanguage: this.acceptedLanguage\n    };\n    dialogConfig.hasBackdrop = true;\n    dialogConfig.disableClose = true;\n    dialogConfig.maxHeight = '80vh';\n    const dialogRef = this.dialog.open(SubmissionModalComponent, dialogConfig);\n  \n    dialogRef.afterClosed().subscribe((result: any) => {\n      if (result) {\n        const hasData = result.rows.flatMap((item: any) => \n          item.grid\n              .some((formElement: any) => formElement.element.answer && formElement.element.answer.length > 0)\n      );\n  \n        if (hasData) {\n          this.subFormSubmission(result);\n        }\n      }\n    });\n  }\n  \n  cleanCircularReferences(obj: any, seen = new WeakSet()) {\n    if (obj === null || typeof obj !== \"object\") {\n      return obj;\n    }\n  \n    if (seen.has(obj)) {\n      return;\n    }\n  \n    seen.add(obj);\n  \n    const cleanedObj: any = Array.isArray(obj) ? [] : {};\n  \n    for (const key in obj) {\n      if (Object.prototype.hasOwnProperty.call(obj, key)) {\n        cleanedObj[key] = this.cleanCircularReferences(obj[key], seen);\n      }\n    }\n  \n    return cleanedObj;\n  }\n\n  updateSubmission(result: any, index: number) {\n    const processFormElements = (rows: any[], answers: Answer[]) => {\n      rows.forEach((row: any) => {\n        row.grid.forEach((grid:any)=>{\n          let answer: Answer = {\n            questionId: grid.element.id,\n            answerId: grid.element?.answerId || '',\n            attachments: grid.element.attachments || [],\n            answer: [],\n            files: [],\n            deleteFiles: [],\n          };\n    \n          if (answer.attachments) {\n            answer.answer = answer.attachments.map(\n              (attachment: Attachment) => attachment.fileName\n            );\n          }\n    \n          if (grid.element.formElement.elementType === 'FILE_PICKER') {\n            if (grid.element?.deleteFiles) {\n              answer.answer = [];\n              grid.element.deleteFiles.forEach((deletedId: string) => {\n                answer.deleteFiles?.push(deletedId);\n                if (answer.attachments) {\n                  answer.attachments = answer.attachments.filter(\n                    (attachment: Attachment) => {\n                      const fileName = attachment.fileName;\n                      if (attachment.fileId !== deletedId) {\n                        if (!answer.answer.includes(fileName)) {\n                          answer.answer.push(fileName);\n                          return true;\n                        }\n                      }\n                      return false;\n                    }\n                  );\n                }\n              });\n            }\n            if (grid.element.answer) {\n              answer.files = grid.element.answer;\n              grid.element.answer.forEach((file: any) => {\n                const fileName = file._file?.name;\n                let fileNamesArray = Array.isArray(answer.answer)\n                  ? answer.answer\n                  : [];\n                if (!fileNamesArray.includes(fileName)) {\n                  fileNamesArray.push(fileName);\n                }\n                answer.answer = fileNamesArray;\n              });\n            }\n          } else {\n            answer = {\n              questionId: grid.element.id,\n              answerId: grid.element?.answerId || '',\n              attachments: grid.element.attachments,\n              answer: grid.element.answer,\n            };\n          }\n          grid.element.answer = '';\n          answers.push(answer);\n    \n          if (grid.element.childLogics) {\n            grid.element.childLogics.forEach((logic: any) => {\n              if(logic.showLogic){\n                processFormElements(logic.rows, answers);\n              }\n            });\n          }\n        })\n      });\n    };\n  \n    this.submissions[index].answers = [];    \n    processFormElements(result.rows, this.submissions[index].answers);\n    this.submissions = [...this.submissions];\n    this.updateSubFormWithSubmissions();\n    this.clearEmptyRows();\n  }  \n\n  updateSubFormWithSubmissions() {\n    this.subForm.submissions = this.submissions;\n    this.subForm.deletedSubmissions = this.deletedSubmissions;\n    this.subFormChange.emit(this.subForm);\n  }\n\n  clearEmptyRows() {\n    const nonEmptySubmissions:Submission[] = [];\n    const emptySubmissionIds:string[] = [];\n  \n    this.submissions.forEach(submission => {\n      if (submission.answers.some(answer => answer.answer !== '')) {\n        nonEmptySubmissions.push(submission);\n      } else if (submission.submissionId) {\n        emptySubmissionIds.push(submission.submissionId);\n      }\n    });\n  \n    this.submissions = nonEmptySubmissions;\n    this.deletedSubmissions.push(...emptySubmissionIds);\n    this.updateSubFormWithSubmissions();\n  }\n  \n}\n","<div class=\"example-container \" tabindex=\"0\">\n  <div class=\"table-container\">\n    <table mat-table [dataSource]=\"submissions\" class=\"mat-elevation-z8\">\n      <ng-container *ngFor=\"let row of subForm.rows\">\n      <ng-container *ngFor=\"let formElement of row.grid\" [matColumnDef]=\"formElement.element.question\">\n        <th mat-header-cell *matHeaderCellDef class=\"border border-1\">{{ formElement.element.question }}</th>\n        <td mat-cell *matCellDef=\"let submission\" class=\"border border-1\" [ngClass]=\"{'hidden': getAnswerByQuestionId(submission, formElement.element.id)?.isChild}\">\n          <div [innerHTML]=\"getAnswerByQuestionId(submission, formElement.element.id)?.htmlContent\"></div>\n        </td>\n      </ng-container>\n    </ng-container>\n      <ng-container matColumnDef=\"actions\" stickyEnd>\n        <th mat-header-cell *matHeaderCellDef  class=\"border border-1\"> Actions </th>\n        <td mat-cell *matCellDef=\"let submission; let i = index\" class=\"text-center border border-1\">\n\n          <div>\n            <button class=\"btn\" mat-icon-button [matMenuTriggerFor]=\"menu\" aria-label=\"Example icon-button with a menu\">\n              <mat-icon>more_vert</mat-icon>\n            </button>\n            <mat-menu #menu=\"matMenu\">\n              <button mat-menu-item  (click)=\"editSubFormSubmission(i, submission)\">\n                <svg width=\"29\" height=\"28\" viewBox=\"0 0 29 28\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                  <rect x=\"0.5\" y=\"0.5\" width=\"28\" height=\"26.4737\" rx=\"5.5\" fill=\"white\" stroke=\"#D8D8D8\"/>\n                  <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12.0009 19.0787H9.1582V16.2361C9.1582 15.9447 9.2739 15.6653 9.47999 15.4593L16.2224 8.71686C16.4284 8.5105 16.708 8.39453 16.9995 8.39453C17.2911 8.39453 17.5707 8.5105 17.7767 8.71686L19.5201 10.4603C19.7264 10.6663 19.8424 10.9458 19.8424 11.2374C19.8424 11.529 19.7264 11.8086 19.5201 12.0145L12.7777 18.757C12.5715 18.9628 12.2922 19.0785 12.0009 19.0787Z\" stroke=\"#084FFF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                  <path d=\"M15.1704 10.3984L17.8415 13.0695\" stroke=\"#084FFF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                </svg>\n              </button>\n              <button mat-menu-item (click)=\"deleteSubForm(i)\">\n                <svg width=\"29\" height=\"28\" viewBox=\"0 0 29 28\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                  <rect x=\"0.5\" y=\"0.5\" width=\"27.6402\" height=\"26.1328\" rx=\"5.5\" fill=\"white\" stroke=\"#D8D8D8\"/>\n                  <path d=\"M8.60449 9.20637H20.0354\" stroke=\"#084FFF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                  <path d=\"M19.2189 9.20703V17.7863C19.2189 18.6482 18.4881 19.3462 17.5859 19.3462H11.0539C10.1517 19.3462 9.4209 18.6482 9.4209 17.7863V9.20703\" stroke=\"#084FFF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                  <path d=\"M16.7696 6.67122H11.8706\" stroke=\"#084FFF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                  <path d=\"M12.6871 12.3242V16.2239\" stroke=\"#084FFF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                  <path d=\"M15.9532 12.3242V16.2239\" stroke=\"#084FFF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                </svg>\n              </button>\n            </mat-menu>\n          </div>\n        </td>\n      </ng-container>\n\n      <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n      <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n    </table>\n  </div>\n  <div class=\"footer\">\n    <div class=\"addNewBtn\" (click)=\"addNewSubmission()\">\n      <svg width=\"15\" height=\"14\" viewBox=\"0 0 15 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M12.5556 13.2778H2.44444C1.64639 13.2778 1 12.6673 1 11.9136V2.3642C1 1.61048 1.64639 1 2.44444 1H12.5556C13.3536 1 14 1.61048 14 2.3642V11.9136C14 12.6673 13.3536 13.2778 12.5556 13.2778Z\" stroke=\"#D8D8D8\" stroke-width=\"0.8\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n        <path d=\"M5.3335 7.50347H9.66683\" stroke=\"#084FFF\" stroke-width=\"0.8\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n        <path d=\"M7.50005 5.33594V9.66927\" stroke=\"#084FFF\" stroke-width=\"0.8\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n      </svg>\n      <a class=\"ms-2 text-decoration-none\">Add New</a>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -3583,11 +3583,12 @@ class MultipleSubformComponent {
|
|
|
3583
3583
|
this.updateSubFormWithSubmissions();
|
|
3584
3584
|
}
|
|
3585
3585
|
addNewSubmission() {
|
|
3586
|
+
const subForm = this.cleanCircularReferences(this.subForm);
|
|
3586
3587
|
const dialogConfig = new MatDialogConfig();
|
|
3587
3588
|
dialogConfig.position = { top: '5%' };
|
|
3588
3589
|
dialogConfig.width = '100%';
|
|
3589
3590
|
dialogConfig.data = {
|
|
3590
|
-
subForm:
|
|
3591
|
+
subForm: subForm,
|
|
3591
3592
|
acceptedLanguage: this.acceptedLanguage
|
|
3592
3593
|
};
|
|
3593
3594
|
dialogConfig.hasBackdrop = true;
|
|
@@ -3604,6 +3605,22 @@ class MultipleSubformComponent {
|
|
|
3604
3605
|
}
|
|
3605
3606
|
});
|
|
3606
3607
|
}
|
|
3608
|
+
cleanCircularReferences(obj, seen = new WeakSet()) {
|
|
3609
|
+
if (obj === null || typeof obj !== "object") {
|
|
3610
|
+
return obj;
|
|
3611
|
+
}
|
|
3612
|
+
if (seen.has(obj)) {
|
|
3613
|
+
return;
|
|
3614
|
+
}
|
|
3615
|
+
seen.add(obj);
|
|
3616
|
+
const cleanedObj = Array.isArray(obj) ? [] : {};
|
|
3617
|
+
for (const key in obj) {
|
|
3618
|
+
if (Object.prototype.hasOwnProperty.call(obj, key)) {
|
|
3619
|
+
cleanedObj[key] = this.cleanCircularReferences(obj[key], seen);
|
|
3620
|
+
}
|
|
3621
|
+
}
|
|
3622
|
+
return cleanedObj;
|
|
3623
|
+
}
|
|
3607
3624
|
updateSubmission(result, index) {
|
|
3608
3625
|
const processFormElements = (rows, answers) => {
|
|
3609
3626
|
rows.forEach((row) => {
|