kwikid-forms
Version:
KwikID's JSON Configuration based Forms Renderer and Builder
152 lines • 24.3 kB
JavaScript
import { __awaiter, __decorate } from "tslib";
import { Component, Input } from "@angular/core";
import { checkObjectKeyExists, getObjectFromLocalStorage, isNotEmptyValue, logMethod } from "kwikid-toolkit";
import { convertFormListConfig } from "./builder.helper";
import * as i0 from "@angular/core";
import * as i1 from "kwikui";
import * as i2 from "./builder-form-list/builder-forms-list.component";
import * as i3 from "./builder-form-editor/builder-form-editor.component";
export class KwikIDFormsBuilderComponent {
constructor(loaderService) {
this.loaderService = loaderService;
this.userConfig = {};
this.formsList = [];
this.activeFormConfig = undefined;
}
ngOnInit() {
const formStepKey = localStorage.getItem("formKey");
if (isNotEmptyValue(formStepKey) &&
checkObjectKeyExists(this.userConfig.userFormFields, formStepKey)) {
this.formsList = convertFormListConfig(this.userConfig.userFormFields[formStepKey]);
}
else if (Array.isArray(this.userConfig.userFormFields)) {
this.formsList = convertFormListConfig(this.userConfig.userFormFields);
}
else {
throw new Error(`userFormFields doesn't have a form defined with key: ${formStepKey}`);
}
}
fetchFormConfig(url) {
return __awaiter(this, void 0, void 0, function* () {
const response = yield fetch(url, { method: "GET" });
const data = yield response.json();
return data;
});
}
/**
* Forms List Listeners
*/
handleGetFormsList(e) {
this.formsList = e.formsList;
}
handleOnClickSetActiveForm(selectedFormKey) {
var _a, _b, _c, _d;
return __awaiter(this, void 0, void 0, function* () {
this.toggleLoader(true);
const activeFormConfig = this.formsList.find((form) => {
return form.key === selectedFormKey;
});
let formConfig;
if (getObjectFromLocalStorage(activeFormConfig.key)) {
formConfig = getObjectFromLocalStorage(activeFormConfig.key);
}
else if (checkObjectKeyExists(activeFormConfig, "props")) {
if (checkObjectKeyExists(activeFormConfig.props, "url")) {
const formConfigFromUrl = yield this.fetchFormConfig(activeFormConfig.props.url);
formConfig = Object.assign(Object.assign({}, activeFormConfig), formConfigFromUrl);
}
else if (checkObjectKeyExists(activeFormConfig.props, "path") &&
checkObjectKeyExists(this.userConfig, "backend") &&
checkObjectKeyExists(this.userConfig.backend, "CONFIG_BASE_URL")) {
const url = `${(_b = (_a = this.userConfig) === null || _a === void 0 ? void 0 : _a.backend) === null || _b === void 0 ? void 0 : _b.CONFIG_BASE_URL}${activeFormConfig.props.path}`;
const formConfigFromPath = yield this.fetchFormConfig(url);
formConfig = Object.assign(Object.assign({}, activeFormConfig), formConfigFromPath);
}
else if (checkObjectKeyExists(activeFormConfig, "fields")) {
formConfig = activeFormConfig;
}
else {
console.error("No Direct URL, No Path with Base URL, No fields key found in Active Form's Config!");
}
}
else if (checkObjectKeyExists(activeFormConfig, "formContent")) {
if (checkObjectKeyExists(activeFormConfig.formContent, "url")) {
const formConfigFromUrl = yield this.fetchFormConfig(activeFormConfig.formContent.url);
formConfig = Object.assign(Object.assign({}, activeFormConfig), formConfigFromUrl);
}
else if (checkObjectKeyExists(activeFormConfig.formContent, "path") &&
checkObjectKeyExists(this.userConfig, "backend") &&
checkObjectKeyExists(this.userConfig.backend, "CONFIG_BASE_URL")) {
const url = `${(_d = (_c = this.userConfig) === null || _c === void 0 ? void 0 : _c.backend) === null || _d === void 0 ? void 0 : _d.CONFIG_BASE_URL}${activeFormConfig.props.path}`;
const formConfigFromPath = yield this.fetchFormConfig(url);
formConfig = Object.assign(Object.assign({}, activeFormConfig), formConfigFromPath);
}
else if (checkObjectKeyExists(activeFormConfig, "fields")) {
formConfig = activeFormConfig;
}
else {
console.error("No Direct URL, No Path with Base URL, No fields key found in Active Form's Config!");
}
}
else if (checkObjectKeyExists(activeFormConfig, "fields")) {
formConfig = activeFormConfig;
}
else {
console.error("No Direct URL, No Path with Base URL, No fields key found in Active Form's Config!");
}
this.activeFormConfig = Object.assign(Object.assign({}, activeFormConfig), formConfig);
this.toggleLoader(false);
});
}
/**
* Form Editor Listeners
*/
handleOnClickSaveActiveFormConfig(activeFormConfig) {
this.activeFormConfig = activeFormConfig;
this.formsList = this.formsList.map((form) => {
if (form.key === activeFormConfig.key) {
return activeFormConfig;
}
return form;
});
}
toggleLoader(loader) {
if (loader) {
this.loaderService.show({
fullscreen: true,
loaderText: "Please wait"
});
}
else {
this.loaderService.hide();
}
}
}
/** @nocollapse */ KwikIDFormsBuilderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikIDFormsBuilderComponent, deps: [{ token: i1.KwikUILoaderService }], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ KwikIDFormsBuilderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: KwikIDFormsBuilderComponent, selector: "kwikid-forms-builder", inputs: { userConfig: "userConfig" }, ngImport: i0, template: "<div class=\"container\">\n <kwikid-builder-forms-list\n [activeFormConfig]=\"this.activeFormConfig\"\n [formsList]=\"this.formsList\"\n (getFormsList)=\"this.handleGetFormsList($event)\"\n (onClickSetActiveForm)=\"this.handleOnClickSetActiveForm($event)\"\n ></kwikid-builder-forms-list>\n <kwikid-builder-form-editor\n [activeFormConfig]=\"activeFormConfig\"\n (onClickSaveActiveFormConfig)=\"\n this.handleOnClickSaveActiveFormConfig($event)\n \"\n ></kwikid-builder-form-editor>\n</div>\n\n<kwikui-loader></kwikui-loader>\n", styles: ["::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{border-radius:10px}::-webkit-scrollbar-thumb{background:lightgray;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:gray}input[type=text],input[type=number]{width:100%;padding:8px 12px;border:1px solid #ccc;border-radius:4px;box-sizing:border-box;appearance:auto!important}input[type=checkbox]{appearance:auto!important;width:1rem;height:1rem}select{width:100%;padding:8px 12px;border:1px solid #ccc;border-radius:4px;box-sizing:border-box}textarea{overflow-wrap:anywhere;resize:none;unicode-bidi:embed;white-space:pre-wrap}button{display:inline-block;padding:8px 12px;background-color:#007bff;color:#fff;text-decoration:none;border-radius:4px;border:none;cursor:pointer}button:hover{background-color:#0069d9}button:active{background-color:#0056b3}button:focus{outline:none}button.secondary{padding:7px 11px;border:1px solid #007bff;background-color:#fff;color:#007bff}button.secondary:hover{background-color:#b7daff}button.secondary:active{background-color:#b7daff}button.secondary:focus{outline:none}.field-container{display:flex}.field-container label{color:gray}.field-container.checkbox{flex-direction:row;align-items:center;justify-content:center;padding:8px 12px;margin:auto}.field-container.options,.field-container.number,.field-container.text{flex-direction:column}.disclaimer{display:flex;flex-direction:column;align-content:center;justify-content:center;align-items:center;color:#121212;width:100%;height:100%}.disclaimer>*:not(:last-child){margin-bottom:1.5rem}.disclaimer .icon{width:3rem;height:3rem;display:flex;flex-direction:row;align-content:center;justify-content:center;align-items:center}.disclaimer.no-form-selected h1{transform:scaleX(-1)}.disclaimer h1{font-size:5rem;font-weight:100}.disclaimer p{font-size:1rem}\n", ":host{all:unset;position:relative;width:100%;height:100%}.container{width:100%;height:100%;display:flex;flex-direction:row;justify-content:space-between;align-items:stretch;padding:1rem}.container>*:not(:last-child){margin-right:1rem}\n"], components: [{ type: i2.KwikIDBuilderFormsListComponent, selector: "kwikid-builder-forms-list", inputs: ["activeFormConfig", "formsList"], outputs: ["onClickSetActiveForm", "getFormsList"] }, { type: i3.KwikIDBuilderFormEditorComponent, selector: "kwikid-builder-form-editor", inputs: ["activeFormConfig"], outputs: ["onClickSaveActiveFormConfig"] }, { type: i1.KwikUILoaderComponent, selector: "kwikui-loader" }] });
__decorate([
logMethod
], KwikIDFormsBuilderComponent.prototype, "fetchFormConfig", null);
__decorate([
logMethod
], KwikIDFormsBuilderComponent.prototype, "handleGetFormsList", null);
__decorate([
logMethod
], KwikIDFormsBuilderComponent.prototype, "handleOnClickSetActiveForm", null);
__decorate([
logMethod
], KwikIDFormsBuilderComponent.prototype, "handleOnClickSaveActiveFormConfig", null);
__decorate([
logMethod
], KwikIDFormsBuilderComponent.prototype, "toggleLoader", null);
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikIDFormsBuilderComponent, decorators: [{
type: Component,
args: [{
selector: "kwikid-forms-builder",
templateUrl: "./builder.component.html",
styleUrls: ["./shared.scss", "./builder.component.scss"]
}]
}], ctorParameters: function () { return [{ type: i1.KwikUILoaderService }]; }, propDecorators: { userConfig: [{
type: Input
}], fetchFormConfig: [], handleGetFormsList: [], handleOnClickSetActiveForm: [], handleOnClickSaveActiveFormConfig: [], toggleLoader: [] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"builder.component.js","sourceRoot":"","sources":["../../../../../projects/kwikid-forms/src/lib/builder/builder.component.ts","../../../../../projects/kwikid-forms/src/lib/builder/builder.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from \"@angular/core\";\nimport {\n  checkObjectKeyExists,\n  getObjectFromLocalStorage,\n  isNotEmptyValue,\n  logMethod\n} from \"kwikid-toolkit\";\nimport { KwikUILoaderService } from \"kwikui\";\nimport { convertFormListConfig } from \"./builder.helper\";\n\n@Component({\n  selector: \"kwikid-forms-builder\",\n  templateUrl: \"./builder.component.html\",\n  styleUrls: [\"./shared.scss\", \"./builder.component.scss\"]\n})\nexport class KwikIDFormsBuilderComponent implements OnInit {\n  @Input()\n  userConfig: any = {};\n\n  formsList = [];\n\n  activeFormConfig: any = undefined;\n\n  constructor(public loaderService: KwikUILoaderService) {}\n\n  ngOnInit() {\n    const formStepKey = localStorage.getItem(\"formKey\");\n\n    if (\n      isNotEmptyValue(formStepKey) &&\n      checkObjectKeyExists(this.userConfig.userFormFields, formStepKey)\n    ) {\n      this.formsList = convertFormListConfig(\n        this.userConfig.userFormFields[formStepKey]\n      );\n    } else if (Array.isArray(this.userConfig.userFormFields)) {\n      this.formsList = convertFormListConfig(this.userConfig.userFormFields);\n    } else {\n      throw new Error(\n        `userFormFields doesn't have a form defined with key: ${formStepKey}`\n      );\n    }\n  }\n\n  @logMethod\n  async fetchFormConfig(url: string) {\n    const response = await fetch(url, { method: \"GET\" });\n    const data = await response.json();\n    return data;\n  }\n\n  /**\n   * Forms List Listeners\n   */\n  @logMethod\n  handleGetFormsList(e: any) {\n    this.formsList = e.formsList;\n  }\n\n  @logMethod\n  async handleOnClickSetActiveForm(selectedFormKey: string) {\n    this.toggleLoader(true);\n\n    const activeFormConfig = this.formsList.find((form) => {\n      return form.key === selectedFormKey;\n    });\n\n    let formConfig: any;\n\n    if (getObjectFromLocalStorage(activeFormConfig.key)) {\n      formConfig = getObjectFromLocalStorage(activeFormConfig.key);\n    } else if (checkObjectKeyExists(activeFormConfig, \"props\")) {\n      if (checkObjectKeyExists(activeFormConfig.props, \"url\")) {\n        const formConfigFromUrl = await this.fetchFormConfig(\n          activeFormConfig.props.url\n        );\n        formConfig = {\n          ...activeFormConfig,\n          ...formConfigFromUrl\n        };\n      } else if (\n        checkObjectKeyExists(activeFormConfig.props, \"path\") &&\n        checkObjectKeyExists(this.userConfig, \"backend\") &&\n        checkObjectKeyExists(this.userConfig.backend, \"CONFIG_BASE_URL\")\n      ) {\n        const url = `${this.userConfig?.backend?.CONFIG_BASE_URL}${activeFormConfig.props.path}`;\n        const formConfigFromPath = await this.fetchFormConfig(url);\n        formConfig = {\n          ...activeFormConfig,\n          ...formConfigFromPath\n        };\n      } else if (checkObjectKeyExists(activeFormConfig, \"fields\")) {\n        formConfig = activeFormConfig;\n      } else {\n        console.error(\n          \"No Direct URL, No Path with Base URL, No fields key found in Active Form's Config!\"\n        );\n      }\n    } else if (checkObjectKeyExists(activeFormConfig, \"formContent\")) {\n      if (checkObjectKeyExists(activeFormConfig.formContent, \"url\")) {\n        const formConfigFromUrl = await this.fetchFormConfig(\n          activeFormConfig.formContent.url\n        );\n        formConfig = {\n          ...activeFormConfig,\n          ...formConfigFromUrl\n        };\n      } else if (\n        checkObjectKeyExists(activeFormConfig.formContent, \"path\") &&\n        checkObjectKeyExists(this.userConfig, \"backend\") &&\n        checkObjectKeyExists(this.userConfig.backend, \"CONFIG_BASE_URL\")\n      ) {\n        const url = `${this.userConfig?.backend?.CONFIG_BASE_URL}${activeFormConfig.props.path}`;\n        const formConfigFromPath = await this.fetchFormConfig(url);\n        formConfig = {\n          ...activeFormConfig,\n          ...formConfigFromPath\n        };\n      } else if (checkObjectKeyExists(activeFormConfig, \"fields\")) {\n        formConfig = activeFormConfig;\n      } else {\n        console.error(\n          \"No Direct URL, No Path with Base URL, No fields key found in Active Form's Config!\"\n        );\n      }\n    } else if (checkObjectKeyExists(activeFormConfig, \"fields\")) {\n      formConfig = activeFormConfig;\n    } else {\n      console.error(\n        \"No Direct URL, No Path with Base URL, No fields key found in Active Form's Config!\"\n      );\n    }\n\n    this.activeFormConfig = {\n      ...activeFormConfig,\n      ...formConfig\n    };\n\n    this.toggleLoader(false);\n  }\n\n  /**\n   * Form Editor Listeners\n   */\n  @logMethod\n  handleOnClickSaveActiveFormConfig(activeFormConfig: any) {\n    this.activeFormConfig = activeFormConfig;\n\n    this.formsList = this.formsList.map((form: any) => {\n      if (form.key === activeFormConfig.key) {\n        return activeFormConfig;\n      }\n      return form;\n    });\n  }\n\n  @logMethod\n  toggleLoader(loader) {\n    if (loader) {\n      this.loaderService.show({\n        fullscreen: true,\n        loaderText: \"Please wait\"\n      });\n    } else {\n      this.loaderService.hide();\n    }\n  }\n}\n","<div class=\"container\">\n  <kwikid-builder-forms-list\n    [activeFormConfig]=\"this.activeFormConfig\"\n    [formsList]=\"this.formsList\"\n    (getFormsList)=\"this.handleGetFormsList($event)\"\n    (onClickSetActiveForm)=\"this.handleOnClickSetActiveForm($event)\"\n  ></kwikid-builder-forms-list>\n  <kwikid-builder-form-editor\n    [activeFormConfig]=\"activeFormConfig\"\n    (onClickSaveActiveFormConfig)=\"\n      this.handleOnClickSaveActiveFormConfig($event)\n    \"\n  ></kwikid-builder-form-editor>\n</div>\n\n<kwikui-loader></kwikui-loader>\n"]}