UNPKG

kwikid-forms

Version:

KwikID's JSON Configuration based Forms Renderer and Builder

241 lines 43.7 kB
import { __decorate } from "tslib"; import { Component, EventEmitter, Input, Output } from "@angular/core"; import { checkObjectKeyExists, checkObjectPathExists, isNull, isUndefined, logMethod, mergeObjects, setValueToObjectPath } from "kwikid-toolkit"; import { getLanguage, updateLanguage } from "../config-converter/config-converter.helper"; import { EFormType } from "../renderer.definitions"; import { ELogEventType } from "./forms-list.definitions"; import { formatEventLogs } from "./forms-list.helper"; import * as i0 from "@angular/core"; import * as i1 from "kwikui"; import * as i2 from "@taiga-ui/core"; import * as i3 from "@angular/common"; export class KwikIDFormsListComponent { constructor() { this.showFormFields = {}; this.userConfig = {}; this.stepConfig = {}; this.activeFormConfig = {}; this.formsList = []; this.formsListCompleted = []; this.isMobileView = false; this.isUnsavedData = false; this.getLogs = new EventEmitter(); this.onClickSetActiveForm = new EventEmitter(); this.onClickHideFormsList = new EventEmitter(); this.onClickSubmitForms = new EventEmitter(); this.selectedForm = ""; this.formsListLength = 0; this.isAllFormsCompleted = true; this.loading = false; } setSelectedForm(selectedForm) { this.selectedForm = selectedForm; } ngOnInit() { var _a, _b; this.loading = true; this.setSelectedForm((_b = (_a = this.activeFormConfig) === null || _a === void 0 ? void 0 : _a.key) !== null && _b !== void 0 ? _b : ""); this.stepConfig = this.formatStepConfig(this.stepConfig); this.triggerLogs(ELogEventType.FORM__STEP_CONFIG_LOAD_SUCCESS, {}); this.formsList = this.filterHiddenForms(this.formsList); this.formsList = this.setFormTitles(this.formsList); this.formsListLength = this.findFormsListLength(this.formsList); this.isAllFormsCompleted = this.checkIsAllFormsCompleted(this.formsList); this.triggerLogs(ELogEventType.FORM__LIST_LOAD_SUCCESS, {}); this.loading = false; } ngOnChanges(changes) { var _a, _b; const verifyChange = (key) => { return checkObjectKeyExists(changes, key) && !changes[key].firstChange; }; if (verifyChange("showFormFields")) { this.showFormFields = changes.showFormFields.currentValue; } if (verifyChange("stepConfig")) { this.stepConfig = changes.stepConfig.currentValue; } if (verifyChange("isUnsavedData")) { this.isUnsavedData = changes.isUnsavedData.currentValue; } if (verifyChange("formsList")) { this.formsList = this.filterHiddenForms(this.formsList); this.formsList = this.setFormTitles(this.formsList); this.formsListLength = this.findFormsListLength(this.formsList); this.isAllFormsCompleted = this.checkIsAllFormsCompleted(this.formsList); } if (verifyChange("isMobileView")) { this.isMobileView = changes.isMobileView.currentValue; if (!this.isMobileView) { this.setSelectedForm(""); } } if (verifyChange("activeFormConfig")) { this.activeFormConfig = changes.activeFormConfig.currentValue; this.setSelectedForm((_b = (_a = this.activeFormConfig) === null || _a === void 0 ? void 0 : _a.key) !== null && _b !== void 0 ? _b : ""); } } triggerLogs(eventType, logs) { this.getLogs.emit(formatEventLogs(eventType, this.stepConfig, logs)); } formatStepConfig(stepConfig) { let stepConfigProperties = { formListProperties: { footer: { submitFormButton: { hidden: false, label: "Submit" } } } }; if (isNull(stepConfig) || isUndefined(stepConfig)) { stepConfig = setValueToObjectPath({}, "props", stepConfigProperties); } else if (checkObjectKeyExists(stepConfig, "props")) { stepConfigProperties = mergeObjects(stepConfigProperties, stepConfig.props); stepConfig = setValueToObjectPath(stepConfig, "props", stepConfigProperties); } else { stepConfig = setValueToObjectPath(stepConfig, "props", stepConfigProperties); } stepConfig.props.formListProperties.footer.submitFormButton.label = updateLanguage(stepConfig.props.formListProperties.footer.submitFormButton.label, getLanguage()); return stepConfig; } filterHiddenForms(formsList) { return formsList.filter((form) => { if (checkObjectKeyExists(form, "hidden")) { return !form.hidden; } return false; }); } setFormTitles(formsList) { return formsList .map((form) => { if (form.type === EFormType.HTML) { return form; // No modification, just return } if (checkObjectPathExists(form, "props.title")) { form.props.title = updateLanguage(form.props.title, getLanguage()); } return form; // Return the form regardless of modification }) .filter((form) => form.type === EFormType.HTML || checkObjectPathExists(form, "props.title")); } findFormsListLength(formsList) { return formsList.filter((form) => { if (checkObjectKeyExists(form, "type")) { return (form.type !== EFormType.HTML && checkObjectKeyExists(form, "hidden") && !form.hidden); } return checkObjectKeyExists(form, "hidden") && !form.hidden; }).length; } checkIsAllFormsCompleted(formsList) { let isAllFormsCompleted = true; for (const form of formsList) { if (checkObjectKeyExists(form, "type")) { if (form.type !== EFormType.HTML) { if (form.status !== "completed") { isAllFormsCompleted = false; break; } } } } return isAllFormsCompleted; } handleOnClickSetActiveForm(selectedForm) { var _a, _b, _c, _d, _e, _f; if (this.isMobileView || (!this.isMobileView && this.selectedForm !== selectedForm) || (this.isAllFormsCompleted && !this.showFormFields)) { if (((_b = (_a = this.activeFormConfig) === null || _a === void 0 ? void 0 : _a.properties) === null || _b === void 0 ? void 0 : _b.isUnsavedDataAlertEnabled) && this.isUnsavedData && !window.confirm("You have unsaved data. Proceed?")) { return; } this.triggerLogs(ELogEventType.FORM__FORM_OPEN_BUTTON_CLICK, { form_key: selectedForm, form_label: (_d = (_c = this.activeFormConfig) === null || _c === void 0 ? void 0 : _c.title) !== null && _d !== void 0 ? _d : (_f = (_e = this.activeFormConfig) === null || _e === void 0 ? void 0 : _e.props) === null || _f === void 0 ? void 0 : _f.title }); this.selectedForm = selectedForm; this.onClickSetActiveForm.emit(selectedForm); } } handleOnSubmitForms(e) { /** * POST ACTIONS * 1. API Calls. * 2. Preview of all filled data. * 3. URL Redirection or new opening of URL in external tab. */ this.onClickSubmitForms.emit(e); } } /** @nocollapse */ KwikIDFormsListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikIDFormsListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); /** @nocollapse */ KwikIDFormsListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: KwikIDFormsListComponent, selector: "kwikid-forms-list", inputs: { showFormFields: "showFormFields", userConfig: "userConfig", stepConfig: "stepConfig", activeFormConfig: "activeFormConfig", formsList: "formsList", formsListCompleted: "formsListCompleted", isMobileView: "isMobileView", isUnsavedData: "isUnsavedData" }, outputs: { getLogs: "getLogs", onClickSetActiveForm: "onClickSetActiveForm", onClickHideFormsList: "onClickHideFormsList", onClickSubmitForms: "onClickSubmitForms" }, usesOnChanges: true, ngImport: i0, template: "<div\n id=\"sidebar-container\"\n *ngIf=\"!loading\"\n>\n <div id=\"sidebar\">\n <div ngClass=\"kwikid-form-header\">\n <div id=\"uf-header\">\n <div id=\"uf-header-logo-container\">\n <img\n id=\"uf-header-logo\"\n src=\"{{ this.userConfig.theme.clientLogo }}\"\n [ngClass]=\"'large-icon'\"\n />\n </div>\n </div>\n <hr />\n </div>\n <div id=\"uf-progress\">\n <div id=\"uf-progress-steps\">\n {{ this.formsListCompleted.length }} / {{ this.formsListLength }} Steps\n Completed\n </div>\n <kwikui-progress-segmented\n [max]=\"this.formsListLength\"\n size=\"m\"\n [value]=\"this.formsListCompleted.length\"\n ></kwikui-progress-segmented>\n </div>\n <div id=\"uf-sections-container\">\n <ng-container *ngFor=\"let form of formsList; let i = index\">\n <ng-container [ngSwitch]=\"form.type\">\n <!-- HTML Content -->\n <ng-container *ngSwitchCase=\"'HTML'\">\n <div [innerHtml]=\"form.props.htmlContent | kwikuiSafeHtml\"></div>\n </ng-container>\n <!-- Type FORM -->\n <ng-container *ngSwitchCase=\"'FORM'\">\n <ng-container\n [ngTemplateOutlet]=\"FORM_BUTTON\"\n [ngTemplateOutletContext]=\"{\n form: form,\n activeFormConfig: activeFormConfig\n }\"\n >\n </ng-container>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n <div id=\"submit-sidebar-btn-container\">\n <kwikui-button\n *ngIf=\"\n !stepConfig.props.formListProperties.footer.submitFormButton.hidden\n \"\n label=\"{{\n stepConfig.props.formListProperties.footer.submitFormButton.label\n }}\"\n type=\"submit\"\n styles=\"width: 100%\"\n (onClick)=\"handleOnSubmitForms($event)\"\n ></kwikui-button>\n </div>\n </div>\n</div>\n\n<ng-template\n #FORM_BUTTON\n let-form=\"form\"\n let-activeFormConfig=\"activeFormConfig\"\n>\n <div\n [class]=\"'uf-section-item'\"\n [class.completed]=\"form.status === 'completed' && !form.disabled\"\n [class.edit]=\"form.status === 'editable' && !form.disabled\"\n [class.locked]=\"form.status === 'locked' && form.disabled\"\n [class.active]=\"\n activeFormConfig !== undefined && form.key === activeFormConfig.key\n \"\n (click)=\"\n form.status === 'locked' && form.disabled\n ? undefined\n : handleOnClickSetActiveForm(form.key)\n \"\n >\n <div class=\"uf-form-section-card-title\">\n {{ form.props.title }}&nbsp;<span *ngIf=\"form?.required\">*</span>\n </div>\n <div class=\"uf-form-section-card-status\">\n <div\n *ngIf=\"form.status === 'completed' && !form.disabled\"\n class=\"uf-form-section-card-status-img completed\"\n >\n <tui-svg src=\"tuiIconCheckLarge\"></tui-svg>\n </div>\n <div\n *ngIf=\"form.status !== 'completed' && !form.disabled\"\n class=\"uf-form-section-card-status-img edit\"\n >\n <tui-svg src=\"tuiIconEdit\"></tui-svg>\n </div>\n <div\n *ngIf=\"form.status !== 'completed' && form.disabled\"\n class=\"uf-form-section-card-status-img locked\"\n >\n <tui-svg src=\"tuiIconLock\"></tui-svg>\n </div>\n </div>\n </div>\n</ng-template>\n", styles: ["#sidebar-container{width:100%;height:100%;margin:0 auto;display:flex;flex-direction:column;justify-content:flex-start;align-items:stretch;align-content:center}#sidebar{width:100%;height:100%;display:flex;flex-direction:column;align-content:center;justify-content:flex-start;align-items:stretch}.uf-section-item{width:100%;display:flex;flex-direction:row;align-items:center;justify-content:space-between;align-content:center;padding:1rem;cursor:pointer;box-shadow:0 1px 3px -1px var(--tui-base-05);border-radius:.5rem;background-color:var(--tui-base-02);position:relative}.uf-section-item>*:not(:last-child){margin-right:1rem}.uf-section-item:hover{box-shadow:0 1px 3px -1px var(--tui-base-08)}#submit-sidebar-btn-container{width:100%;bottom:0px;z-index:1;padding:1rem;display:flex;flex-direction:row;align-content:center;justify-content:center;align-items:center}#submit-sidebar-btn-container>*:not(:last-child){margin-right:1rem}#submit-sidebar-btn-container *{flex-grow:1}#uf-sections-container{display:flex;flex-direction:column;height:100%;padding:1rem;overflow-y:auto}#uf-sections-container>*:not(:last-child){margin-bottom:1rem}.uf-form-section-card{display:flex;flex-direction:row;align-content:center;justify-content:space-between;align-items:center;border:none;border-radius:8px;background-color:#e9e9e9;height:-moz-fit-content;height:fit-content;min-height:60px;padding:10px 15px;width:100%;max-width:350px;margin:0 auto}.uf-form-section-card>*:not(:last-child){margin-right:.5rem}.uf-section-item.locked{-webkit-user-select:none;user-select:none;cursor:not-allowed}.uf-form-section-card .uf-form-section-card-title{font-size:1.2em;text-align:left;line-height:1.25em}.uf-form-section-card .uf-form-section-card-status{width:30px;height:30px;display:flex;flex-direction:row;align-content:center;justify-content:center;align-items:center}.uf-form-section-card .uf-form-section-card-status .uf-form-section-card-status-img{width:30px;height:30px;display:flex;flex-direction:row;align-content:center;justify-content:center;align-items:center;border-radius:100%;color:#fff;font-weight:bold}.uf-form-section-card-status-img.completed{background-color:var(--tui-success-fill);padding:.25rem;border-radius:50%;color:#fff}.uf-form-section-card-status-img.edit{background-color:var(--tui-error-fill);padding:.25rem;border-radius:50%;color:#fff}.uf-form-section-card-status-img.locked{background-color:var(--tui-neutral-fill);padding:.25rem;border-radius:50%;color:#fff}#uf-progress{display:flex;padding:1rem;flex-direction:column;align-content:center;justify-content:center;align-items:stretch}#uf-progress>*:not(:last-child){margin-bottom:.5rem}#uf-progress-steps{font-size:1em;text-align:right;color:#3d3d3d}.uf-form-section-card-title{font-size:1em;font-weight:bold;color:#000}@media screen and (max-width: 600px){#sidebar-container{max-width:unset}}.kwikid-form-header{height:70px;z-index:6}.kwikid-form-header hr{width:calc(100% - 1rem);margin-left:auto;margin-right:auto}#uf-header{display:flex;flex-direction:row;align-content:center;align-items:center;justify-content:flex-start;padding:10px 20px;width:100%;max-width:calc(400px + 50vw + 2rem);margin:0 auto;height:70px;z-index:1}#uf-header>*:not(:last-child){margin-right:1rem}#uf-header #uf-header-goback-container{display:none}#uf-header #uf-header-goback-container:hover{border-radius:50%;background-color:#d3d3d3}#uf-header #uf-header-goback-container #uf-header-goback{width:100%;height:auto}#uf-header #uf-header-logo-container{display:flex;flex-direction:row;align-content:center;justify-content:center;align-items:center}#uf-header #uf-header-logo-container #uf-header-logo.small-icon{width:100%;height:50px}#uf-header #uf-header-logo-container #uf-header-logo.large-icon{width:100%;height:50px}#uf-header #uf-header-title-container{display:flex;flex-direction:column;justify-content:center;align-items:flex-start}#uf-header #uf-header-title-container>*:not(:last-child){margin-bottom:.5rem}#uf-header #uf-header-title-container #uf-header-title{font-size:1.4em;color:#121212}#uf-header #uf-header-title-container #uf-header-subtitle{font-size:1.2em;color:#121212}\n", "::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{border-radius:10px}::-webkit-scrollbar-thumb{background:lightgray;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:gray}\n"], components: [{ type: i1.KwikUIProgressSegmentedComponent, selector: "kwikui-progress-segmented", inputs: ["colors", "id", "max", "size", "value"] }, { type: i1.KwikUIButtonComponent, selector: "kwikui-button", inputs: ["appearance", "class", "disabled", "icon", "iconRight", "id", "label", "shape", "showLoader", "size", "styles", "type", "pseudoHover"], outputs: ["onClick"] }, { type: i2.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "kwikuiSafeHtml": i1.KwikUISafeHtmlPipe } }); __decorate([ logMethod ], KwikIDFormsListComponent.prototype, "ngOnChanges", null); __decorate([ logMethod ], KwikIDFormsListComponent.prototype, "triggerLogs", null); __decorate([ logMethod ], KwikIDFormsListComponent.prototype, "formatStepConfig", null); __decorate([ logMethod ], KwikIDFormsListComponent.prototype, "filterHiddenForms", null); __decorate([ logMethod ], KwikIDFormsListComponent.prototype, "setFormTitles", null); __decorate([ logMethod ], KwikIDFormsListComponent.prototype, "findFormsListLength", null); __decorate([ logMethod ], KwikIDFormsListComponent.prototype, "checkIsAllFormsCompleted", null); __decorate([ logMethod ], KwikIDFormsListComponent.prototype, "handleOnClickSetActiveForm", null); __decorate([ logMethod ], KwikIDFormsListComponent.prototype, "handleOnSubmitForms", null); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikIDFormsListComponent, decorators: [{ type: Component, args: [{ selector: "kwikid-forms-list", templateUrl: "./forms-list.component.html", styleUrls: ["./forms-list.component.scss", "../shared.scss"] }] }], propDecorators: { showFormFields: [{ type: Input }], userConfig: [{ type: Input }], stepConfig: [{ type: Input }], activeFormConfig: [{ type: Input }], formsList: [{ type: Input }], formsListCompleted: [{ type: Input }], isMobileView: [{ type: Input }], isUnsavedData: [{ type: Input }], getLogs: [{ type: Output }], onClickSetActiveForm: [{ type: Output }], onClickHideFormsList: [{ type: Output }], onClickSubmitForms: [{ type: Output }], ngOnChanges: [], triggerLogs: [], formatStepConfig: [], filterHiddenForms: [], setFormTitles: [], findFormsListLength: [], checkIsAllFormsCompleted: [], handleOnClickSetActiveForm: [], handleOnSubmitForms: [] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"forms-list.component.js","sourceRoot":"","sources":["../../../../../../projects/kwikid-forms/src/lib/renderer/forms-list/forms-list.component.ts","../../../../../../projects/kwikid-forms/src/lib/renderer/forms-list/forms-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges\n} from \"@angular/core\";\nimport {\n  checkObjectKeyExists,\n  checkObjectPathExists,\n  isNull,\n  isUndefined,\n  logMethod,\n  mergeObjects,\n  setValueToObjectPath\n} from \"kwikid-toolkit\";\nimport {\n  getLanguage,\n  updateLanguage\n} from \"../config-converter/config-converter.helper\";\nimport { EFormType } from \"../renderer.definitions\";\nimport { ELogEventType } from \"./forms-list.definitions\";\nimport { formatEventLogs } from \"./forms-list.helper\";\n\n@Component({\n  selector: \"kwikid-forms-list\",\n  templateUrl: \"./forms-list.component.html\",\n  styleUrls: [\"./forms-list.component.scss\", \"../shared.scss\"]\n})\nexport class KwikIDFormsListComponent implements OnInit, OnChanges {\n  @Input()\n  showFormFields: any = {};\n\n  @Input()\n  userConfig: any = {};\n\n  @Input()\n  stepConfig: any = {};\n\n  @Input()\n  activeFormConfig: any = {};\n\n  @Input()\n  formsList: any[] = [];\n\n  @Input()\n  formsListCompleted: any[] = [];\n\n  @Input()\n  isMobileView = false;\n\n  @Input()\n  isUnsavedData = false;\n\n  @Output()\n  getLogs: EventEmitter<any> = new EventEmitter<any>();\n\n  @Output()\n  onClickSetActiveForm: EventEmitter<any> = new EventEmitter<any>();\n\n  @Output()\n  onClickHideFormsList: EventEmitter<any> = new EventEmitter<any>();\n\n  @Output()\n  onClickSubmitForms = new EventEmitter<any>();\n\n  selectedForm = \"\";\n\n  setSelectedForm(selectedForm: string): void {\n    this.selectedForm = selectedForm;\n  }\n\n  formsListLength = 0;\n\n  isAllFormsCompleted = true;\n\n  loading = false;\n\n  ngOnInit(): void {\n    this.loading = true;\n\n    this.setSelectedForm(this.activeFormConfig?.key ?? \"\");\n\n    this.stepConfig = this.formatStepConfig(this.stepConfig);\n\n    this.triggerLogs(ELogEventType.FORM__STEP_CONFIG_LOAD_SUCCESS, {});\n\n    this.formsList = this.filterHiddenForms(this.formsList);\n    this.formsList = this.setFormTitles(this.formsList);\n    this.formsListLength = this.findFormsListLength(this.formsList);\n    this.isAllFormsCompleted = this.checkIsAllFormsCompleted(this.formsList);\n\n    this.triggerLogs(ELogEventType.FORM__LIST_LOAD_SUCCESS, {});\n\n    this.loading = false;\n  }\n\n  @logMethod\n  ngOnChanges(changes: SimpleChanges): void {\n    const verifyChange = (key: string) => {\n      return checkObjectKeyExists(changes, key) && !changes[key].firstChange;\n    };\n    if (verifyChange(\"showFormFields\")) {\n      this.showFormFields = changes.showFormFields.currentValue;\n    }\n    if (verifyChange(\"stepConfig\")) {\n      this.stepConfig = changes.stepConfig.currentValue;\n    }\n    if (verifyChange(\"isUnsavedData\")) {\n      this.isUnsavedData = changes.isUnsavedData.currentValue;\n    }\n    if (verifyChange(\"formsList\")) {\n      this.formsList = this.filterHiddenForms(this.formsList);\n      this.formsList = this.setFormTitles(this.formsList);\n      this.formsListLength = this.findFormsListLength(this.formsList);\n      this.isAllFormsCompleted = this.checkIsAllFormsCompleted(this.formsList);\n    }\n    if (verifyChange(\"isMobileView\")) {\n      this.isMobileView = changes.isMobileView.currentValue;\n\n      if (!this.isMobileView) {\n        this.setSelectedForm(\"\");\n      }\n    }\n    if (verifyChange(\"activeFormConfig\")) {\n      this.activeFormConfig = changes.activeFormConfig.currentValue;\n\n      this.setSelectedForm(this.activeFormConfig?.key ?? \"\");\n    }\n  }\n\n  @logMethod\n  triggerLogs(eventType: ELogEventType, logs: any) {\n    this.getLogs.emit(formatEventLogs(eventType, this.stepConfig, logs));\n  }\n\n  @logMethod\n  formatStepConfig(stepConfig: any): any {\n    let stepConfigProperties = {\n      formListProperties: {\n        footer: {\n          submitFormButton: {\n            hidden: false,\n            label: \"Submit\"\n          }\n        }\n      }\n    };\n\n    if (isNull(stepConfig) || isUndefined(stepConfig)) {\n      stepConfig = setValueToObjectPath({}, \"props\", stepConfigProperties);\n    } else if (checkObjectKeyExists(stepConfig, \"props\")) {\n      stepConfigProperties = mergeObjects(\n        stepConfigProperties,\n        stepConfig.props\n      );\n\n      stepConfig = setValueToObjectPath(\n        stepConfig,\n        \"props\",\n        stepConfigProperties\n      );\n    } else {\n      stepConfig = setValueToObjectPath(\n        stepConfig,\n        \"props\",\n        stepConfigProperties\n      );\n    }\n\n    stepConfig.props.formListProperties.footer.submitFormButton.label =\n      updateLanguage(\n        stepConfig.props.formListProperties.footer.submitFormButton.label,\n        getLanguage()\n      );\n\n    return stepConfig;\n  }\n\n  @logMethod\n  filterHiddenForms(formsList: any[]): any[] {\n    return formsList.filter((form) => {\n      if (checkObjectKeyExists(form, \"hidden\")) {\n        return !form.hidden;\n      }\n      return false;\n    });\n  }\n\n  @logMethod\n  setFormTitles(formsList: any[]): any[] {\n    return formsList\n      .map((form) => {\n        if (form.type === EFormType.HTML) {\n          return form; // No modification, just return\n        }\n        if (checkObjectPathExists(form, \"props.title\")) {\n          form.props.title = updateLanguage(form.props.title, getLanguage());\n        }\n        return form; // Return the form regardless of modification\n      })\n      .filter(\n        (form) =>\n          form.type === EFormType.HTML ||\n          checkObjectPathExists(form, \"props.title\")\n      );\n  }\n\n  @logMethod\n  findFormsListLength(formsList: any[]): number {\n    return formsList.filter((form) => {\n      if (checkObjectKeyExists(form, \"type\")) {\n        return (\n          form.type !== EFormType.HTML &&\n          checkObjectKeyExists(form, \"hidden\") &&\n          !form.hidden\n        );\n      }\n      return checkObjectKeyExists(form, \"hidden\") && !form.hidden;\n    }).length;\n  }\n\n  @logMethod\n  checkIsAllFormsCompleted(formsList: any[]): boolean {\n    let isAllFormsCompleted = true;\n\n    for (const form of formsList) {\n      if (checkObjectKeyExists(form, \"type\")) {\n        if (form.type !== EFormType.HTML) {\n          if (form.status !== \"completed\") {\n            isAllFormsCompleted = false;\n            break;\n          }\n        }\n      }\n    }\n\n    return isAllFormsCompleted;\n  }\n\n  @logMethod\n  handleOnClickSetActiveForm(selectedForm: string) {\n    if (\n      this.isMobileView ||\n      (!this.isMobileView && this.selectedForm !== selectedForm) ||\n      (this.isAllFormsCompleted && !this.showFormFields)\n    ) {\n      if (\n        this.activeFormConfig?.properties?.isUnsavedDataAlertEnabled &&\n        this.isUnsavedData &&\n        !window.confirm(\"You have unsaved data. Proceed?\")\n      ) {\n        return;\n      }\n      this.triggerLogs(ELogEventType.FORM__FORM_OPEN_BUTTON_CLICK, {\n        form_key: selectedForm,\n        form_label:\n          this.activeFormConfig?.title ?? this.activeFormConfig?.props?.title\n      });\n\n      this.selectedForm = selectedForm;\n      this.onClickSetActiveForm.emit(selectedForm);\n    }\n  }\n\n  @logMethod\n  handleOnSubmitForms(e: any) {\n    /**\n     * POST ACTIONS\n     * 1. API Calls.\n     * 2. Preview of all filled data.\n     * 3. URL Redirection or new opening of URL in external tab.\n     */\n\n    this.onClickSubmitForms.emit(e);\n  }\n}\n","<div\n  id=\"sidebar-container\"\n  *ngIf=\"!loading\"\n>\n  <div id=\"sidebar\">\n    <div ngClass=\"kwikid-form-header\">\n      <div id=\"uf-header\">\n        <div id=\"uf-header-logo-container\">\n          <img\n            id=\"uf-header-logo\"\n            src=\"{{ this.userConfig.theme.clientLogo }}\"\n            [ngClass]=\"'large-icon'\"\n          />\n        </div>\n      </div>\n      <hr />\n    </div>\n    <div id=\"uf-progress\">\n      <div id=\"uf-progress-steps\">\n        {{ this.formsListCompleted.length }} / {{ this.formsListLength }} Steps\n        Completed\n      </div>\n      <kwikui-progress-segmented\n        [max]=\"this.formsListLength\"\n        size=\"m\"\n        [value]=\"this.formsListCompleted.length\"\n      ></kwikui-progress-segmented>\n    </div>\n    <div id=\"uf-sections-container\">\n      <ng-container *ngFor=\"let form of formsList; let i = index\">\n        <ng-container [ngSwitch]=\"form.type\">\n          <!-- HTML Content -->\n          <ng-container *ngSwitchCase=\"'HTML'\">\n            <div [innerHtml]=\"form.props.htmlContent | kwikuiSafeHtml\"></div>\n          </ng-container>\n          <!-- Type FORM -->\n          <ng-container *ngSwitchCase=\"'FORM'\">\n            <ng-container\n              [ngTemplateOutlet]=\"FORM_BUTTON\"\n              [ngTemplateOutletContext]=\"{\n                form: form,\n                activeFormConfig: activeFormConfig\n              }\"\n            >\n            </ng-container>\n          </ng-container>\n        </ng-container>\n      </ng-container>\n    </div>\n    <div id=\"submit-sidebar-btn-container\">\n      <kwikui-button\n        *ngIf=\"\n          !stepConfig.props.formListProperties.footer.submitFormButton.hidden\n        \"\n        label=\"{{\n          stepConfig.props.formListProperties.footer.submitFormButton.label\n        }}\"\n        type=\"submit\"\n        styles=\"width: 100%\"\n        (onClick)=\"handleOnSubmitForms($event)\"\n      ></kwikui-button>\n    </div>\n  </div>\n</div>\n\n<ng-template\n  #FORM_BUTTON\n  let-form=\"form\"\n  let-activeFormConfig=\"activeFormConfig\"\n>\n  <div\n    [class]=\"'uf-section-item'\"\n    [class.completed]=\"form.status === 'completed' && !form.disabled\"\n    [class.edit]=\"form.status === 'editable' && !form.disabled\"\n    [class.locked]=\"form.status === 'locked' && form.disabled\"\n    [class.active]=\"\n      activeFormConfig !== undefined && form.key === activeFormConfig.key\n    \"\n    (click)=\"\n      form.status === 'locked' && form.disabled\n        ? undefined\n        : handleOnClickSetActiveForm(form.key)\n    \"\n  >\n    <div class=\"uf-form-section-card-title\">\n      {{ form.props.title }}&nbsp;<span *ngIf=\"form?.required\">*</span>\n    </div>\n    <div class=\"uf-form-section-card-status\">\n      <div\n        *ngIf=\"form.status === 'completed' && !form.disabled\"\n        class=\"uf-form-section-card-status-img completed\"\n      >\n        <tui-svg src=\"tuiIconCheckLarge\"></tui-svg>\n      </div>\n      <div\n        *ngIf=\"form.status !== 'completed' && !form.disabled\"\n        class=\"uf-form-section-card-status-img edit\"\n      >\n        <tui-svg src=\"tuiIconEdit\"></tui-svg>\n      </div>\n      <div\n        *ngIf=\"form.status !== 'completed' && form.disabled\"\n        class=\"uf-form-section-card-status-img locked\"\n      >\n        <tui-svg src=\"tuiIconLock\"></tui-svg>\n      </div>\n    </div>\n  </div>\n</ng-template>\n"]}