@piserve-tech/form-submission 1.3.161 → 1.3.162

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.
@@ -70,8 +70,8 @@ export class SubFormComponent {
70
70
  }
71
71
  bindAnswersToFormElements() {
72
72
  const bindAnswers = (formElements, submissions) => {
73
- formElements.forEach((grids) => {
74
- grids.grid.forEach((formElement) => {
73
+ formElements?.forEach((grids) => {
74
+ grids?.grid?.forEach((formElement) => {
75
75
  if (formElement.entityType === 'QUESTION') {
76
76
  const submission = submissions.find((sub) => sub.answers.some((ans) => ans.questionId === formElement.element.id));
77
77
  if (submission) {
@@ -86,7 +86,7 @@ export class SubFormComponent {
86
86
  }
87
87
  if (formElement.element.childLogics) {
88
88
  formElement.element.childLogics.forEach((childLogic) => {
89
- bindAnswers(childLogic.formElements, submissions);
89
+ bindAnswers(childLogic.rows, submissions);
90
90
  });
91
91
  }
92
92
  }
@@ -121,4 +121,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
121
121
  }], acceptedLanguage: [{
122
122
  type: Input
123
123
  }] } });
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sub-form.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/question/sub-form/sub-form.component.ts","../../../../../projects/form-submission/src/question/sub-form/sub-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Injector,\n  Input,\n  OnInit,\n  Output,\n} from '@angular/core';\n\n@Component({\n  selector: 'lib-sub-form',\n  templateUrl: './sub-form.component.html',\n  styleUrls: ['./sub-form.component.scss'],\n})\nexport class SubFormComponent implements OnInit {\n  @Input() subForm: any = {};\n  @Input() edit: boolean = false;\n  @Output() subFormChange = new EventEmitter<any>();\n  @Input() acceptedLanguage: string = '';\n  decodedDescription: string = '';\n  grid: any;\n  state!: string;\n  childLogicCache: { [key: string]: { component: Promise<any>, injector: Injector } } = {};\n  componentToLoad: any;\n  injector!: Injector;\n\n  ngOnInit() {\n    if (this.subForm.property.subFormStructure == 'single') {\n      this.bindAnswersToFormElements();\n      this.loadComponent();\n    }\n  }\n  \n  // getComponentForChildLogics(grid: any, state: string, answer: any): { component: Promise<any>, injector: Injector } {\n  //   const key = JSON.stringify({grid, state}); // or use hash\n  //   if (!this.childLogicCache[key]) {\n  //     const component = this.loadFormElementsComponent();\n  //     const injector = this.createInjector(grid, state, answer);\n  //     this.childLogicCache[key] = { component, injector };\n  //   }\n  //   return this.childLogicCache[key];\n  // }\n\n  private async loadComponent(): Promise<void> {\n    this.componentToLoad = await this.loadFormElementsComponent();\n    this.injector = this.createInjector();\n  }\n  \n  private async loadFormElementsComponent() {\n    const { FormElementsComponent } = await import('../form-elements/form-elements.component');\n    return FormElementsComponent;    \n  }\n\n  createInjector(): Injector {\n    return Injector.create({\n      providers: [\n        { provide: 'grid', useValue: this.grid?.element.childLogics  },\n        { provide: 'state', useValue: 'child' },\n      ],\n    });\n  }\n\n  decodeHtml(html: string): string {\n    const textArea = document.createElement('textarea');\n    textArea.innerHTML = html;\n    return textArea.value;\n  }\n\n  bindAnswersToFormElements() {\n    const bindAnswers = (formElements: any[], submissions: any[]) => {\n      formElements.forEach((grids: any) => {\n        grids.grid.forEach(\n          (formElement: { entityType: string; element: any }) => {\n            if (formElement.entityType === 'QUESTION') {\n              const submission = submissions.find((sub: { answers: any[] }) =>\n                sub.answers.some(\n                  (ans: { questionId: any }) =>\n                    ans.questionId === formElement.element.id\n                )\n              );\n\n              if (submission) {\n                const answer = submission.answers.find(\n                  (ans: { questionId: any }) =>\n                    ans.questionId === formElement.element.id\n                );\n                if (answer) {\n                  formElement.element.answer = answer.answer;\n                  formElement.element.answerId = answer.answerId;\n                  formElement.element.validation = true;\n                  formElement.element.attachments = answer.attachments;\n                  this.subForm.submissionId = submission.submissionId;\n                }\n              }\n\n              if (formElement.element.childLogics) {\n                formElement.element.childLogics.forEach(\n                  (childLogic: { formElements: any[] }) => {\n                    bindAnswers(childLogic.formElements, submissions);\n                  }\n                );\n              }\n            }\n          }\n        );\n      });\n    };\n\n    if (this.subForm && this.subForm.rows && this.subForm.submissions) {\n      bindAnswers(this.subForm.rows, this.subForm.submissions);\n    }\n  }\n\n  updateSubFormWithSubmissions(event: any) {\n    this.subForm = event;\n    this.subFormChange.emit(this.subForm);\n  }\n\n  ngOnChanges(): void {\n    if (this.subForm.description) {\n      this.decodedDescription = this.decodeHtml(this.subForm.description);\n    }\n  }\n}\n","<div class=\"outer-container mb-4 px-3\" [id]=\"'question-'+subForm.id\">\n  <div class=\"body container pt-3 pb-3 px-3\">\n    <div class=\"tab-content pt-4 pb-3 px-3\">\n      <p class=\"sectionTitle\">{{ subForm.title }}</p>\n      <p [innerHTML]=\"decodedDescription\" class=\"description\"></p>\n\n      <div *ngIf=\"subForm.property.subFormStructure == 'multiple'\">\n        <lib-multiple-subform *ngIf=\"!subForm.property.enableInlineEditing\" [subForm]=\"subForm\"\n          (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n          [acceptedLanguage]=\"acceptedLanguage\"></lib-multiple-subform>\n\n        <lib-inline-multiple-subform *ngIf=\"subForm.property.enableInlineEditing\" [subForm]=\"subForm\"\n          (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n          [acceptedLanguage]=\"acceptedLanguage\"></lib-inline-multiple-subform>\n      </div>\n      <div *ngIf=\"subForm.property.subFormStructure == 'single'\">\n        <div *ngFor=\"let row of subForm.rows\">\n          <div class=\"d-flex\">\n            <div *ngFor=\"let grid of row.grid\" [ngStyle]=\"{'width.%': (grid.element.count) * (100 / 12)}\">\n              <div *ngIf=\"grid.entityType === 'QUESTION'\">\n                <div [ngSwitch]=\"grid.element.formElement.elementType\">\n                  <lib-check-box-fields *ngSwitchCase=\"'CHECK_BOX'\" [question]=\"grid.element\"></lib-check-box-fields>\n                  <lib-date-time-fields *ngSwitchCase=\"'DATE_TIME'\" [question]=\"grid.element\"></lib-date-time-fields>\n                  <lib-drop-down-fields *ngSwitchCase=\"'DROP_DOWN'\" [question]=\"grid.element\"></lib-drop-down-fields>\n                  <lib-file-picker-fields *ngSwitchCase=\"'FILE_PICKER'\"\n                    [question]=\"grid.element\"></lib-file-picker-fields>\n                  <lib-location-fields *ngSwitchCase=\"'LOCATION'\" [question]=\"grid.element\"></lib-location-fields>\n                  <lib-mail-fields *ngSwitchCase=\"'EMAIL'\" [question]=\"grid.element\"></lib-mail-fields>\n                  <lib-mobile-fields *ngSwitchCase=\"'MOBILE'\" [question]=\"grid.element\"></lib-mobile-fields>\n                  <lib-number-fields *ngSwitchCase=\"'NUMBER'\" [question]=\"grid.element\"></lib-number-fields>\n                  <lib-password-fields *ngSwitchCase=\"'PASSWORD'\" [question]=\"grid.element\"></lib-password-fields>\n                  <lib-radio-button-fields *ngSwitchCase=\"'RADIO_BUTTON'\"\n                    [question]=\"grid.element\"></lib-radio-button-fields>\n                  <lib-rich-text-editor-fields *ngSwitchCase=\"'RICH_TEXT_EDITOR'\"\n                    [question]=\"grid.element\"></lib-rich-text-editor-fields>\n                  <lib-selection-matrix-fields *ngSwitchCase=\"'SELECTION_MATRIX'\" [question]=\"grid.element\"\n                    [acceptedLanguage]=\"acceptedLanguage\"></lib-selection-matrix-fields>\n                  <lib-signature-fields *ngSwitchCase=\"'SIGNATURE'\" [question]=\"grid.element\"></lib-signature-fields>\n                  <lib-slider-fields *ngSwitchCase=\"'SLIDER'\" [question]=\"grid.element\"></lib-slider-fields>\n                  <lib-terms-and-condition-fields *ngSwitchCase=\"'TERMS_AND_CONDITION'\"\n                    [question]=\"grid.element\"></lib-terms-and-condition-fields>\n                  <lib-text-area-fields *ngSwitchCase=\"'TEXT_AREA'\" [question]=\"grid.element\"></lib-text-area-fields>\n                  <lib-text-fields *ngSwitchCase=\"'TEXT_BOX'\" [question]=\"grid.element\"></lib-text-fields>\n                  <lib-toggle-switch-fields *ngSwitchCase=\"'TOGGLE_SWITCH'\" [question]=\"grid.element\"\n                    [acceptedLanguage]=\"acceptedLanguage\"></lib-toggle-switch-fields>\n                  <lib-url-fields *ngSwitchCase=\"'URL'\" [question]=\"grid.element\"></lib-url-fields>\n                </div>\n  \n                <!-- <ng-container *ngIf=\"grid.element.childLogics\">\n                  <ng-container\n                    *ngIf=\"getComponentForChildLogics(grid.element.childLogics, 'child', grid.element.answer) as outlet\">\n                    <ng-container *ngComponentOutlet=\"outlet.component | async; injector: outlet.injector\">\n                    </ng-container>\n                  </ng-container>\n                </ng-container> -->\n                <ng-container *ngIf=\"grid?.element?.childLogics\">\n              \n                  <ng-container *ngIf=\"componentToLoad\">\n       \n                    <ng-container *ngComponentOutlet=\"componentToLoad; \n                                                      inputs: { grid: grid?.element?.childLogics, \n                                                                answer: 'an', \n                                                                state: 'child' }\"></ng-container>\n                  </ng-container>\n                </ng-container>\n            </div>\n  \n              <div *ngIf=\"grid.entityType === 'SECTION'\">\n                <lib-section-fields [section]=\"grid.element\"></lib-section-fields>\n              </div>\n            </div>\n          </div>\n          \n        </div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sub-form.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/question/sub-form/sub-form.component.ts","../../../../../projects/form-submission/src/question/sub-form/sub-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Injector,\n  Input,\n  OnInit,\n  Output,\n} from '@angular/core';\n\n@Component({\n  selector: 'lib-sub-form',\n  templateUrl: './sub-form.component.html',\n  styleUrls: ['./sub-form.component.scss'],\n})\nexport class SubFormComponent implements OnInit {\n  @Input() subForm: any = {};\n  @Input() edit: boolean = false;\n  @Output() subFormChange = new EventEmitter<any>();\n  @Input() acceptedLanguage: string = '';\n  decodedDescription: string = '';\n  grid: any;\n  state!: string;\n  childLogicCache: { [key: string]: { component: Promise<any>, injector: Injector } } = {};\n  componentToLoad: any;\n  injector!: Injector;\n\n  ngOnInit() {\n    if (this.subForm.property.subFormStructure == 'single') {\n      this.bindAnswersToFormElements();\n      this.loadComponent();\n    }\n  }\n  \n  // getComponentForChildLogics(grid: any, state: string, answer: any): { component: Promise<any>, injector: Injector } {\n  //   const key = JSON.stringify({grid, state}); // or use hash\n  //   if (!this.childLogicCache[key]) {\n  //     const component = this.loadFormElementsComponent();\n  //     const injector = this.createInjector(grid, state, answer);\n  //     this.childLogicCache[key] = { component, injector };\n  //   }\n  //   return this.childLogicCache[key];\n  // }\n\n  private async loadComponent(): Promise<void> {\n    this.componentToLoad = await this.loadFormElementsComponent();\n    this.injector = this.createInjector();\n  }\n  \n  private async loadFormElementsComponent() {\n    const { FormElementsComponent } = await import('../form-elements/form-elements.component');\n    return FormElementsComponent;    \n  }\n\n  createInjector(): Injector {\n    return Injector.create({\n      providers: [\n        { provide: 'grid', useValue: this.grid?.element.childLogics  },\n        { provide: 'state', useValue: 'child' },\n      ],\n    });\n  }\n\n  decodeHtml(html: string): string {\n    const textArea = document.createElement('textarea');\n    textArea.innerHTML = html;\n    return textArea.value;\n  }\n\n  bindAnswersToFormElements() {\n    const bindAnswers = (formElements: any[], submissions: any[]) => {\n      formElements?.forEach((grids: any) => {\n        grids?.grid?.forEach(\n          (formElement: { entityType: string; element: any }) => {\n            if (formElement.entityType === 'QUESTION') {\n              const submission = submissions.find((sub: { answers: any[] }) =>\n                sub.answers.some(\n                  (ans: { questionId: any }) =>\n                    ans.questionId === formElement.element.id\n                )\n              );\n\n              if (submission) {\n                const answer = submission.answers.find(\n                  (ans: { questionId: any }) =>\n                    ans.questionId === formElement.element.id\n                );\n                if (answer) {\n                  formElement.element.answer = answer.answer;\n                  formElement.element.answerId = answer.answerId;\n                  formElement.element.validation = true;\n                  formElement.element.attachments = answer.attachments;\n                  this.subForm.submissionId = submission.submissionId;\n                }\n              }\n\n              if (formElement.element.childLogics) {\n                formElement.element.childLogics.forEach(\n                  (childLogic: { rows: any[] }) => {\n                    bindAnswers(childLogic.rows, submissions);\n                  }\n                );\n              }\n            }\n          }\n        );\n      });\n    };\n\n    if (this.subForm && this.subForm.rows && this.subForm.submissions) {\n      bindAnswers(this.subForm.rows, this.subForm.submissions);\n    }\n  }\n\n  updateSubFormWithSubmissions(event: any) {\n    this.subForm = event;\n    this.subFormChange.emit(this.subForm);\n  }\n\n  ngOnChanges(): void {\n    if (this.subForm.description) {\n      this.decodedDescription = this.decodeHtml(this.subForm.description);\n    }\n  }\n}\n","<div class=\"outer-container mb-4 px-3\" [id]=\"'question-'+subForm.id\">\n  <div class=\"body container pt-3 pb-3 px-3\">\n    <div class=\"tab-content pt-4 pb-3 px-3\">\n      <p class=\"sectionTitle\">{{ subForm.title }}</p>\n      <p [innerHTML]=\"decodedDescription\" class=\"description\"></p>\n\n      <div *ngIf=\"subForm.property.subFormStructure == 'multiple'\">\n        <lib-multiple-subform *ngIf=\"!subForm.property.enableInlineEditing\" [subForm]=\"subForm\"\n          (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n          [acceptedLanguage]=\"acceptedLanguage\"></lib-multiple-subform>\n\n        <lib-inline-multiple-subform *ngIf=\"subForm.property.enableInlineEditing\" [subForm]=\"subForm\"\n          (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n          [acceptedLanguage]=\"acceptedLanguage\"></lib-inline-multiple-subform>\n      </div>\n      <div *ngIf=\"subForm.property.subFormStructure == 'single'\">\n        <div *ngFor=\"let row of subForm.rows\">\n          <div class=\"d-flex\">\n            <div *ngFor=\"let grid of row.grid\" [ngStyle]=\"{'width.%': (grid.element.count) * (100 / 12)}\">\n              <div *ngIf=\"grid.entityType === 'QUESTION'\">\n                <div [ngSwitch]=\"grid.element.formElement.elementType\">\n                  <lib-check-box-fields *ngSwitchCase=\"'CHECK_BOX'\" [question]=\"grid.element\"></lib-check-box-fields>\n                  <lib-date-time-fields *ngSwitchCase=\"'DATE_TIME'\" [question]=\"grid.element\"></lib-date-time-fields>\n                  <lib-drop-down-fields *ngSwitchCase=\"'DROP_DOWN'\" [question]=\"grid.element\"></lib-drop-down-fields>\n                  <lib-file-picker-fields *ngSwitchCase=\"'FILE_PICKER'\"\n                    [question]=\"grid.element\"></lib-file-picker-fields>\n                  <lib-location-fields *ngSwitchCase=\"'LOCATION'\" [question]=\"grid.element\"></lib-location-fields>\n                  <lib-mail-fields *ngSwitchCase=\"'EMAIL'\" [question]=\"grid.element\"></lib-mail-fields>\n                  <lib-mobile-fields *ngSwitchCase=\"'MOBILE'\" [question]=\"grid.element\"></lib-mobile-fields>\n                  <lib-number-fields *ngSwitchCase=\"'NUMBER'\" [question]=\"grid.element\"></lib-number-fields>\n                  <lib-password-fields *ngSwitchCase=\"'PASSWORD'\" [question]=\"grid.element\"></lib-password-fields>\n                  <lib-radio-button-fields *ngSwitchCase=\"'RADIO_BUTTON'\"\n                    [question]=\"grid.element\"></lib-radio-button-fields>\n                  <lib-rich-text-editor-fields *ngSwitchCase=\"'RICH_TEXT_EDITOR'\"\n                    [question]=\"grid.element\"></lib-rich-text-editor-fields>\n                  <lib-selection-matrix-fields *ngSwitchCase=\"'SELECTION_MATRIX'\" [question]=\"grid.element\"\n                    [acceptedLanguage]=\"acceptedLanguage\"></lib-selection-matrix-fields>\n                  <lib-signature-fields *ngSwitchCase=\"'SIGNATURE'\" [question]=\"grid.element\"></lib-signature-fields>\n                  <lib-slider-fields *ngSwitchCase=\"'SLIDER'\" [question]=\"grid.element\"></lib-slider-fields>\n                  <lib-terms-and-condition-fields *ngSwitchCase=\"'TERMS_AND_CONDITION'\"\n                    [question]=\"grid.element\"></lib-terms-and-condition-fields>\n                  <lib-text-area-fields *ngSwitchCase=\"'TEXT_AREA'\" [question]=\"grid.element\"></lib-text-area-fields>\n                  <lib-text-fields *ngSwitchCase=\"'TEXT_BOX'\" [question]=\"grid.element\"></lib-text-fields>\n                  <lib-toggle-switch-fields *ngSwitchCase=\"'TOGGLE_SWITCH'\" [question]=\"grid.element\"\n                    [acceptedLanguage]=\"acceptedLanguage\"></lib-toggle-switch-fields>\n                  <lib-url-fields *ngSwitchCase=\"'URL'\" [question]=\"grid.element\"></lib-url-fields>\n                </div>\n  \n                <!-- <ng-container *ngIf=\"grid.element.childLogics\">\n                  <ng-container\n                    *ngIf=\"getComponentForChildLogics(grid.element.childLogics, 'child', grid.element.answer) as outlet\">\n                    <ng-container *ngComponentOutlet=\"outlet.component | async; injector: outlet.injector\">\n                    </ng-container>\n                  </ng-container>\n                </ng-container> -->\n                <ng-container *ngIf=\"grid?.element?.childLogics\">\n              \n                  <ng-container *ngIf=\"componentToLoad\">\n       \n                    <ng-container *ngComponentOutlet=\"componentToLoad; \n                                                      inputs: { grid: grid?.element?.childLogics, \n                                                                answer: 'an', \n                                                                state: 'child' }\"></ng-container>\n                  </ng-container>\n                </ng-container>\n            </div>\n  \n              <div *ngIf=\"grid.entityType === 'SECTION'\">\n                <lib-section-fields [section]=\"grid.element\"></lib-section-fields>\n              </div>\n            </div>\n          </div>\n          \n        </div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
@@ -4740,8 +4740,8 @@ class SubFormComponent {
4740
4740
  }
4741
4741
  bindAnswersToFormElements() {
4742
4742
  const bindAnswers = (formElements, submissions) => {
4743
- formElements.forEach((grids) => {
4744
- grids.grid.forEach((formElement) => {
4743
+ formElements?.forEach((grids) => {
4744
+ grids?.grid?.forEach((formElement) => {
4745
4745
  if (formElement.entityType === 'QUESTION') {
4746
4746
  const submission = submissions.find((sub) => sub.answers.some((ans) => ans.questionId === formElement.element.id));
4747
4747
  if (submission) {
@@ -4756,7 +4756,7 @@ class SubFormComponent {
4756
4756
  }
4757
4757
  if (formElement.element.childLogics) {
4758
4758
  formElement.element.childLogics.forEach((childLogic) => {
4759
- bindAnswers(childLogic.formElements, submissions);
4759
+ bindAnswers(childLogic.rows, submissions);
4760
4760
  });
4761
4761
  }
4762
4762
  }