UNPKG

@formio-tmt/angular

Version:

This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 10.1.4.

123 lines 20 kB
import { Component, ViewChild } from '@angular/core'; import { FormBuilderComponent } from '@formio-tmt/angular'; import _ from 'lodash'; import * as i0 from "@angular/core"; import * as i1 from "../form-manager.service"; import * as i2 from "@angular/router"; import * as i3 from "../form-manager.config"; import * as i4 from "@formio-tmt/angular"; import * as i5 from "@angular/common"; import * as i6 from "@angular/forms"; class FormManagerEditComponent { service; router; route; config; ref; alerts; builder; formTitle; formType; form; loading; formReady; editMode; constructor(service, router, route, config, ref, alerts) { this.service = service; this.router = router; this.route = route; this.config = config; this.ref = ref; this.alerts = alerts; this.form = { components: [] }; this.formReady = false; this.loading = false; this.editMode = false; } initBuilder(editing) { if (editing) { this.loading = true; this.editMode = true; return this.service.formReady.then(() => { this.form = this.service.form; this.formTitle.nativeElement.value = this.service.form.title; this.formType.nativeElement.value = this.service.form.display || 'form'; this.formReady = true; this.loading = false; this.ref.detectChanges(); return true; }).catch(err => { this.alerts.setAlert({ type: 'danger', message: (err.message || err) }); this.loading = false; this.ref.detectChanges(); this.formReady = true; }); } else { this.formReady = true; return Promise.resolve(true); } } ngAfterViewInit() { this.route.url.subscribe(url => { setTimeout(() => this.initBuilder((url[0].path === 'edit')), 0); }); } onDisplaySelect(event) { this.builder.setDisplay(event.target.value); } saveForm() { this.loading = true; this.form = _.cloneDeep(this.builder.formio.schema); this.form.title = this.formTitle.nativeElement.value.trim(); this.form.display = this.formType.nativeElement.value; if (this.config.tag) { this.form.tags = this.form.tags || []; this.form.tags.push(this.config.tag); this.form.tags = _.uniq(this.form.tags); } if (!this.form._id) { this.form.name = _.camelCase(this.form.title).toLowerCase(); this.form.path = this.form.name; } return this.service.formio.saveForm(this.form).then(form => { this.form = this.service.setForm(form); this.loading = false; return this.form; }).catch(err => { this.loading = false; // Catch if a form is returned as an error. This is a conflict. if (err._id && err.type) { throw err; } this.alerts.setAlert({ type: 'danger', message: (err.message || err) }); }); } onSave() { return this.saveForm().then((form) => { if (this.editMode) { this.router.navigate(['../', 'view'], { relativeTo: this.route }); } else { this.router.navigate(['../', form._id, 'view'], { relativeTo: this.route }); } }); } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: FormManagerEditComponent, deps: [{ token: i1.FormManagerService }, { token: i2.Router }, { token: i2.ActivatedRoute }, { token: i3.FormManagerConfig }, { token: i0.ChangeDetectorRef }, { token: i4.FormioAlerts }], target: i0.ɵɵFactoryTarget.Component }); static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: FormManagerEditComponent, selector: "ng-component", viewQueries: [{ propertyName: "builder", first: true, predicate: FormBuilderComponent, descendants: true }, { propertyName: "formTitle", first: true, predicate: ["title"], descendants: true }, { propertyName: "formType", first: true, predicate: ["type"], descendants: true }], ngImport: i0, template: "<div class=\"loader\" *ngIf=\"loading\"></div>\r\n<div class=\"form-group row mb-2\">\r\n <div class=\"col-sm-8\">\r\n <input type=\"text\" class=\"form-control\" id=\"formTitle\" placeholder=\"Enter a Title\" #title>\r\n </div>\r\n <div class=\"col-sm-2\">\r\n <select class=\"form-control\" id=\"formSelect\" (change)=\"onDisplaySelect($event)\" #type>\r\n <option value=\"form\">Form</option>\r\n <option value=\"wizard\">Wizard</option>\r\n <option value=\"pdf\">PDF</option>\r\n </select>\r\n </div>\r\n <div class=\"col-sm-2\">\r\n <button class=\"btn btn-primary btn-block\" (click)=\"onSave()\"><i class=\"bi bi-save me-2\"></i>Save Form</button>\r\n </div>\r\n</div>\r\n<formio-alerts [alerts]=\"alerts\"></formio-alerts>\r\n<form-builder *ngIf=\"formReady\" [formbuilder]=\"config.builder\" [form]=\"form\" #builder></form-builder>\r\n<button class=\"btn btn-primary\" style=\"margin-top: 10px;\" (click)=\"onSave()\">Save Form</button>\r\n", dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.FormBuilderComponent, selector: "form-builder", inputs: ["form", "options", "formbuilder", "noeval", "refresh", "rebuild"], outputs: ["change"] }, { kind: "component", type: i4.FormioAlertsComponent, selector: "formio-alerts", inputs: ["alerts"], outputs: ["focusComponent"] }, { kind: "directive", type: i6.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i6.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }] }); } export { FormManagerEditComponent }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: FormManagerEditComponent, decorators: [{ type: Component, args: [{ template: "<div class=\"loader\" *ngIf=\"loading\"></div>\r\n<div class=\"form-group row mb-2\">\r\n <div class=\"col-sm-8\">\r\n <input type=\"text\" class=\"form-control\" id=\"formTitle\" placeholder=\"Enter a Title\" #title>\r\n </div>\r\n <div class=\"col-sm-2\">\r\n <select class=\"form-control\" id=\"formSelect\" (change)=\"onDisplaySelect($event)\" #type>\r\n <option value=\"form\">Form</option>\r\n <option value=\"wizard\">Wizard</option>\r\n <option value=\"pdf\">PDF</option>\r\n </select>\r\n </div>\r\n <div class=\"col-sm-2\">\r\n <button class=\"btn btn-primary btn-block\" (click)=\"onSave()\"><i class=\"bi bi-save me-2\"></i>Save Form</button>\r\n </div>\r\n</div>\r\n<formio-alerts [alerts]=\"alerts\"></formio-alerts>\r\n<form-builder *ngIf=\"formReady\" [formbuilder]=\"config.builder\" [form]=\"form\" #builder></form-builder>\r\n<button class=\"btn btn-primary\" style=\"margin-top: 10px;\" (click)=\"onSave()\">Save Form</button>\r\n" }] }], ctorParameters: function () { return [{ type: i1.FormManagerService }, { type: i2.Router }, { type: i2.ActivatedRoute }, { type: i3.FormManagerConfig }, { type: i0.ChangeDetectorRef }, { type: i4.FormioAlerts }]; }, propDecorators: { builder: [{ type: ViewChild, args: [FormBuilderComponent, { static: false }] }], formTitle: [{ type: ViewChild, args: ['title', { static: false }] }], formType: [{ type: ViewChild, args: ['type', { static: false }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit.component.js","sourceRoot":"","sources":["../../../../../projects/angular-formio/manager/src/edit/edit.component.ts","../../../../../projects/angular-formio/manager/src/edit/edit.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild, ElementRef, AfterViewInit, ChangeDetectorRef } from '@angular/core';\r\nimport { FormManagerService } from '../form-manager.service';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { FormManagerConfig } from '../form-manager.config';\r\nimport { FormioAlerts } from '@formio-tmt/angular';\r\nimport { FormBuilderComponent } from '@formio-tmt/angular';\r\nimport _ from 'lodash';\r\n\r\n@Component({\r\n  templateUrl: './edit.component.html'\r\n})\r\nexport class FormManagerEditComponent implements AfterViewInit {\r\n  @ViewChild(FormBuilderComponent, {static: false}) builder: FormBuilderComponent;\r\n  @ViewChild('title', {static: false}) formTitle: ElementRef;\r\n  @ViewChild('type', {static: false}) formType: ElementRef;\r\n  public form: any;\r\n  public loading: Boolean;\r\n  public formReady: Boolean;\r\n  public editMode: Boolean;\r\n\r\n  constructor(\r\n    public service: FormManagerService,\r\n    public router: Router,\r\n    public route: ActivatedRoute,\r\n    public config: FormManagerConfig,\r\n    public ref: ChangeDetectorRef,\r\n    public alerts: FormioAlerts\r\n  ) {\r\n    this.form = {components: []};\r\n    this.formReady = false;\r\n    this.loading = false;\r\n    this.editMode = false;\r\n  }\r\n\r\n  initBuilder(editing) {\r\n    if (editing) {\r\n      this.loading = true;\r\n      this.editMode = true;\r\n      return this.service.formReady.then(() => {\r\n        this.form = this.service.form;\r\n        this.formTitle.nativeElement.value = this.service.form.title;\r\n        this.formType.nativeElement.value = this.service.form.display || 'form';\r\n        this.formReady = true;\r\n        this.loading = false;\r\n        this.ref.detectChanges();\r\n        return true;\r\n      }).catch(err => {\r\n        this.alerts.setAlert({type: 'danger', message: (err.message || err)});\r\n        this.loading = false;\r\n        this.ref.detectChanges();\r\n        this.formReady = true;\r\n      });\r\n    } else {\r\n      this.formReady = true;\r\n      return Promise.resolve(true);\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.route.url.subscribe( url => {\r\n      setTimeout(() => this.initBuilder((url[0].path === 'edit')), 0);\r\n    });\r\n  }\r\n\r\n  onDisplaySelect(event) {\r\n    this.builder.setDisplay(event.target.value);\r\n  }\r\n\r\n  saveForm() {\r\n    this.loading = true;\r\n    this.form = _.cloneDeep(this.builder.formio.schema);\r\n    this.form.title = this.formTitle.nativeElement.value.trim();\r\n    this.form.display = this.formType.nativeElement.value;\r\n\r\n    if (this.config.tag) {\r\n      this.form.tags = this.form.tags || [];\r\n      this.form.tags.push(this.config.tag);\r\n      this.form.tags = _.uniq(this.form.tags);\r\n    }\r\n    if (!this.form._id) {\r\n      this.form.name = _.camelCase(this.form.title).toLowerCase();\r\n      this.form.path = this.form.name;\r\n    }\r\n    return this.service.formio.saveForm(this.form).then(form => {\r\n      this.form = this.service.setForm(form);\r\n      this.loading = false;\r\n      return this.form;\r\n    }).catch(err => {\r\n      this.loading = false;\r\n      // Catch if a form is returned as an error. This is a conflict.\r\n      if (err._id && err.type) {\r\n        throw err;\r\n      }\r\n      this.alerts.setAlert({type: 'danger', message: (err.message || err)});\r\n    });\r\n  }\r\n\r\n  onSave() {\r\n    return this.saveForm().then((form) => {\r\n      if (this.editMode) {\r\n        this.router.navigate(['../', 'view'], {relativeTo: this.route});\r\n      } else {\r\n        this.router.navigate(['../', form._id, 'view'], {relativeTo: this.route});\r\n      }\r\n    });\r\n  }\r\n}\r\n","<div class=\"loader\" *ngIf=\"loading\"></div>\r\n<div class=\"form-group row mb-2\">\r\n  <div class=\"col-sm-8\">\r\n    <input type=\"text\" class=\"form-control\" id=\"formTitle\" placeholder=\"Enter a Title\" #title>\r\n  </div>\r\n  <div class=\"col-sm-2\">\r\n    <select class=\"form-control\" id=\"formSelect\" (change)=\"onDisplaySelect($event)\" #type>\r\n      <option value=\"form\">Form</option>\r\n      <option value=\"wizard\">Wizard</option>\r\n      <option value=\"pdf\">PDF</option>\r\n    </select>\r\n  </div>\r\n  <div class=\"col-sm-2\">\r\n    <button class=\"btn btn-primary btn-block\" (click)=\"onSave()\"><i class=\"bi bi-save me-2\"></i>Save Form</button>\r\n  </div>\r\n</div>\r\n<formio-alerts [alerts]=\"alerts\"></formio-alerts>\r\n<form-builder *ngIf=\"formReady\" [formbuilder]=\"config.builder\" [form]=\"form\" #builder></form-builder>\r\n<button class=\"btn btn-primary\" style=\"margin-top: 10px;\" (click)=\"onSave()\">Save Form</button>\r\n"]}