UNPKG

kwikid-forms

Version:

KwikID's JSON Configuration based Forms Renderer and Builder

96 lines 23.2 kB
import { __decorate } from "tslib"; import { Component, EventEmitter, Input, Output } from "@angular/core"; import { FormControl, FormGroup, Validators } from "@angular/forms"; import { checkObjectKeyExists, getObjectDeepCopy, isEmptyValue, logMethod } from "kwikid-toolkit"; import { convertFormListConfig } from "../builder.helper"; import * as i0 from "@angular/core"; import * as i1 from "kwikui"; import * as i2 from "@taiga-ui/core"; import * as i3 from "@angular/forms"; import * as i4 from "@angular/common"; export class KwikIDBuilderFormsListComponent { constructor() { this.activeFormConfig = {}; this.formsList = []; this.onClickSetActiveForm = new EventEmitter(); this.getFormsList = new EventEmitter(); this.selectedForm = ""; this.addForm = new FormGroup({ key: new FormControl("", Validators.required), title: new FormControl("", Validators.required) }); } setSelectedForm(selectedForm) { this.selectedForm = selectedForm; } ngOnChanges(changes) { const verifyChange = (key) => { return checkObjectKeyExists(changes, key) && !changes[key].firstChange; }; if (verifyChange("activeFormConfig")) { this.activeFormConfig = changes.activeFormConfig.currentValue; } if (verifyChange("formsList")) { this.formsList = changes.formsList.currentValue; } } handleOnClickSetActiveForm(selectedForm) { if (this.selectedForm !== selectedForm) { this.selectedForm = selectedForm; this.onClickSetActiveForm.emit(selectedForm); } } handleOnClickAddForm() { if (this.addForm.invalid) { alert("Please fill all the fields"); } else { if (isEmptyValue(this.activeFormConfig)) { this.activeFormConfig = { key: this.addForm.value.key.toUpperCase(), title: this.addForm.value.title, type: "FORM" }; } const newForm = { key: this.addForm.value.key.toUpperCase(), title: this.addForm.value.title, type: "FORM", fields: [], required: true }; this.formsList.push(newForm); this.formsList = getObjectDeepCopy(convertFormListConfig(this.formsList)); this.addForm.reset(); this.getFormsList.emit({ formsList: this.formsList }); } } } /** @nocollapse */ KwikIDBuilderFormsListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikIDBuilderFormsListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); /** @nocollapse */ KwikIDBuilderFormsListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: KwikIDBuilderFormsListComponent, selector: "kwikid-builder-forms-list", inputs: { activeFormConfig: "activeFormConfig", formsList: "formsList" }, outputs: { onClickSetActiveForm: "onClickSetActiveForm", getFormsList: "getFormsList" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"container\">\n <form\n class=\"add-form-container\"\n [formGroup]=\"addForm\"\n >\n <input\n type=\"text\"\n formControlName=\"key\"\n placeholder=\"form key\"\n />\n <input\n type=\"text\"\n formControlName=\"title\"\n placeholder=\"form title\"\n />\n <kwikui-button\n size=\"s\"\n styles=\"width: 100%\"\n label=\"add form\"\n shape=\"rounded\"\n (click)=\"handleOnClickAddForm()\"\n ></kwikui-button>\n </form>\n <hr />\n <div class=\"forms-list\">\n <ng-container *ngIf=\"formsList.length > 0; else NoForms\">\n <ng-container *ngFor=\"let form of formsList\">\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 </ng-container>\n <ng-template #NoForms>\n <div class=\"no-form\">\n <div class=\"no-fields disclaimer\">\n <div class=\"icon\"><h1>&plus;</h1></div>\n <div><p>Please add a new form to start</p></div>\n </div>\n </div>\n </ng-template>\n </div>\n <ng-container *ngIf=\"formsList.length > 0\">\n <hr />\n <div>\n <b>Total Forms: {{ formsList.length }}</b>\n </div>\n </ng-container>\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.active]=\"\n activeFormConfig !== undefined && form.key === activeFormConfig.key\n \"\n (click)=\"handleOnClickSetActiveForm(form.key)\"\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 class=\"uf-form-section-card-status-img edit\">\n <tui-svg src=\"tuiIconEdit\"></tui-svg>\n </div>\n </div>\n </div>\n</ng-template>\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;height:100%}.container{width:100%;min-width:280px;max-width:400px;height:100%;display:flex;flex-direction:column;align-content:flex-start;justify-content:space-between;align-items:stretch;padding:1rem;border:1px solid #ccc}.container>*:not(:last-child){margin-bottom:1rem}.container .add-form-container{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-end}.container .add-form-container>*:not(:last-child){margin-bottom:1rem}.container .forms-list{display:flex;flex-direction:column;align-content:center;justify-content:flex-start;align-items:stretch;flex-grow:1;overflow:auto;padding-right:.5rem}.container .forms-list>*:not(:last-child){margin-bottom:1rem}.container .forms-list .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}.container .forms-list .uf-section-item>*:not(:last-child){margin-right:1rem}.container .forms-list .uf-section-item:hover{box-shadow:0 1px 3px -1px var(--tui-base-08)}.container .forms-list .uf-section-item .uf-form-section-card-title{font-size:1em;text-align:left;line-height:1.25em;font-weight:bold;white-space:nowrap}.container .forms-list .uf-section-item .uf-form-section-card-status{width:30px;height:30px;display:flex;flex-direction:row;align-content:center;justify-content:center;align-items:center}.container .forms-list .uf-section-item .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}.container .forms-list .uf-section-item .uf-form-section-card-status .uf-form-section-card-status-img.edit{background-color:var(--tui-error-fill);padding:.25rem;border-radius:50%;color:#fff}.container .forms-list .form-item{background-color:#ccc3;border:1px solid gray;color:gray;cursor:pointer;display:inline-block;padding:12px 6px;text-decoration:none}.container .forms-list .form-item.active{background-color:#007bff0f;border:1px solid #007bff;color:#007bff}.container .forms-list .form-item.active span{transform:scaleX(-1)}.container .forms-list .no-form{height:100%;display:flex;flex-direction:row;align-content:center;justify-content:center;align-items:center;text-align:center}\n"], components: [{ 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.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.FormControlName, selector: "[formControlName]", inputs: ["disabled", "formControlName", "ngModel"], outputs: ["ngModelChange"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i4.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "kwikuiSafeHtml": i1.KwikUISafeHtmlPipe } }); __decorate([ logMethod ], KwikIDBuilderFormsListComponent.prototype, "ngOnChanges", null); __decorate([ logMethod ], KwikIDBuilderFormsListComponent.prototype, "handleOnClickSetActiveForm", null); __decorate([ logMethod ], KwikIDBuilderFormsListComponent.prototype, "handleOnClickAddForm", null); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikIDBuilderFormsListComponent, decorators: [{ type: Component, args: [{ selector: "kwikid-builder-forms-list", templateUrl: "./builder-forms-list.component.html", styleUrls: ["../shared.scss", "./builder-forms-list.component.scss"] }] }], propDecorators: { activeFormConfig: [{ type: Input }], formsList: [{ type: Input }], onClickSetActiveForm: [{ type: Output }], getFormsList: [{ type: Output }], ngOnChanges: [], handleOnClickSetActiveForm: [], handleOnClickAddForm: [] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"builder-forms-list.component.js","sourceRoot":"","sources":["../../../../../../projects/kwikid-forms/src/lib/builder/builder-form-list/builder-forms-list.component.ts","../../../../../../projects/kwikid-forms/src/lib/builder/builder-form-list/builder-forms-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges\n} from \"@angular/core\";\nimport { FormControl, FormGroup, Validators } from \"@angular/forms\";\nimport {\n  checkObjectKeyExists,\n  getObjectDeepCopy,\n  isEmptyValue,\n  logMethod\n} from \"kwikid-toolkit\";\nimport { convertFormListConfig } from \"../builder.helper\";\n\n@Component({\n  selector: \"kwikid-builder-forms-list\",\n  templateUrl: \"./builder-forms-list.component.html\",\n  styleUrls: [\"../shared.scss\", \"./builder-forms-list.component.scss\"]\n})\nexport class KwikIDBuilderFormsListComponent implements OnChanges {\n  @Input()\n  activeFormConfig: any = {};\n\n  @Input()\n  formsList: any[] = [];\n\n  @Output()\n  onClickSetActiveForm: EventEmitter<any> = new EventEmitter<any>();\n\n  @Output()\n  getFormsList: EventEmitter<any> = new EventEmitter<any>();\n\n  selectedForm = \"\";\n\n  setSelectedForm(selectedForm: string): void {\n    this.selectedForm = selectedForm;\n  }\n\n  addForm: FormGroup = new FormGroup({\n    key: new FormControl(\"\", Validators.required),\n    title: new FormControl(\"\", Validators.required)\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(\"activeFormConfig\")) {\n      this.activeFormConfig = changes.activeFormConfig.currentValue;\n    }\n    if (verifyChange(\"formsList\")) {\n      this.formsList = changes.formsList.currentValue;\n    }\n  }\n\n  @logMethod\n  handleOnClickSetActiveForm(selectedForm: string) {\n    if (this.selectedForm !== selectedForm) {\n      this.selectedForm = selectedForm;\n      this.onClickSetActiveForm.emit(selectedForm);\n    }\n  }\n\n  @logMethod\n  handleOnClickAddForm() {\n    if (this.addForm.invalid) {\n      alert(\"Please fill all the fields\");\n    } else {\n      if (isEmptyValue(this.activeFormConfig)) {\n        this.activeFormConfig = {\n          key: this.addForm.value.key.toUpperCase(),\n          title: this.addForm.value.title,\n          type: \"FORM\"\n        };\n      }\n\n      const newForm = {\n        key: this.addForm.value.key.toUpperCase(),\n        title: this.addForm.value.title,\n        type: \"FORM\",\n        fields: [],\n        required: true\n      };\n      this.formsList.push(newForm);\n      this.formsList = getObjectDeepCopy(convertFormListConfig(this.formsList));\n      this.addForm.reset();\n\n      this.getFormsList.emit({ formsList: this.formsList });\n    }\n  }\n}\n","<div class=\"container\">\n  <form\n    class=\"add-form-container\"\n    [formGroup]=\"addForm\"\n  >\n    <input\n      type=\"text\"\n      formControlName=\"key\"\n      placeholder=\"form key\"\n    />\n    <input\n      type=\"text\"\n      formControlName=\"title\"\n      placeholder=\"form title\"\n    />\n    <kwikui-button\n      size=\"s\"\n      styles=\"width: 100%\"\n      label=\"add form\"\n      shape=\"rounded\"\n      (click)=\"handleOnClickAddForm()\"\n    ></kwikui-button>\n  </form>\n  <hr />\n  <div class=\"forms-list\">\n    <ng-container *ngIf=\"formsList.length > 0; else NoForms\">\n      <ng-container *ngFor=\"let form of formsList\">\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    </ng-container>\n    <ng-template #NoForms>\n      <div class=\"no-form\">\n        <div class=\"no-fields disclaimer\">\n          <div class=\"icon\"><h1>&plus;</h1></div>\n          <div><p>Please add a new form to start</p></div>\n        </div>\n      </div>\n    </ng-template>\n  </div>\n  <ng-container *ngIf=\"formsList.length > 0\">\n    <hr />\n    <div>\n      <b>Total Forms: {{ formsList.length }}</b>\n    </div>\n  </ng-container>\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.active]=\"\n      activeFormConfig !== undefined && form.key === activeFormConfig.key\n    \"\n    (click)=\"handleOnClickSetActiveForm(form.key)\"\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 class=\"uf-form-section-card-status-img edit\">\n        <tui-svg src=\"tuiIconEdit\"></tui-svg>\n      </div>\n    </div>\n  </div>\n</ng-template>\n"]}