form.io: не рендеринг пользовательского компонента

Я пытаюсь использовать https://form.io/ с пользовательским компонентом под названием MeComponent но это не рендеринг. Я не могу понять, чего мне не хватает. Это то, что я пробовал.

app.module.ts

import { BrowserModule } from "@angular/platform-browser";
import { NgModule } from "@angular/core";
import { FormioModule } from "angular-formio";

import { FormSchemaService } from "./services/form-schema.service";

import { AppComponent } from "./app.component";
import { MeComponent } from "./me/me.component";

@NgModule({
  declarations: [MeComponent, AppComponent],
  imports: [BrowserModule, FormioModule],
  providers: [FormSchemaService],
  bootstrap: [AppComponent]
})
export class AppModule {}

app.component.ts

import { Component } from "@angular/core";
import { FormSchemaService } from "./services/form-schema.service";
import { OnInit } from "@angular/core/src/metadata/lifecycle_hooks";
@Component({
  selector: "app-root",
  templateUrl: "./app.component.html",
  styleUrls: ["./app.component.css"]
})
export class AppComponent implements OnInit {
  public title = "Playing with form.io";
  public data = [];

  public formConfig = {
    submission: {
      data: {
        firstName: "Joe",
        lastName: "Smith"
      }
    },
    options: {
      alerts: {
        submitMessage: "Thank you for something."
      },
      errors: {
        message: "Something is not right. Please call 911."
      },
      hooks: {
        beforeSubmit: ($event, callback) => {
          console.log("form.io --> beforeSubmit: ", $event);
          setTimeout(() => {
            console.log(callback);
            // Callback with a possibly manipulated submission.
            //  callback("Something wen wrong", null);
            // callback(null, $event);
            callback(
              {
                message: "Something bad happened.",
                component: null
              },
              null
            );
          }, 1000);
        }
      }
    }
  };

  constructor(private schemaService: FormSchemaService) {}

  public ngOnInit() {
    const sub$ = this.schemaService.getFormSchema().subscribe(data => {
      this.data = data;
      sub$.unsubscribe();
    });
  }

  public onSubmit($event) {
    console.log($event);
  }
}

app.component.html

<h2>{{title}}</h2>
<hr>
<formio [form]="data" (submit)="onSubmit($event)" [submission]="formConfig.submission" [options]="formConfig.options"></formio>

Вот сервис, который предоставляет данные:

форм-schema.service.ts

import { Injectable } from "@angular/core";
import { Observable } from "rxjs/Observable";

import "rxjs/add/operator/delay";
import "rxjs/add/observable/of";

const data = {
  title: "My Test Form",
  components: [
    {
      type: "textfield",
      input: true,
      tableView: true,
      inputType: "text",
      inputMask: "",
      label: "First Name",
      key: "firstName",
      placeholder: "Enter your first name",
      prefix: "",
      suffix: "",
      multiple: false,
      customClass: "text-loud",
      protected: false,
      unique: false,
      persistent: true,
      validate: {
        required: true,
        minLength: 2,
        maxLength: 10,
        pattern: "",
        custom: "",
        customPrivate: false
      },
      conditional: {
        show: "",
        when: null,
        eq: ""
      }
    },
    {
      type: "textfield",
      input: true,
      tableView: true,
      inputType: "text",
      inputMask: "",
      label: "Last Name",
      key: "lastName",
      placeholder: "Enter your last name",
      prefix: "",
      suffix: "",
      multiple: false,
      protected: false,
      unique: false,
      persistent: true,
      validate: {
        required: true,
        minLength: 2,
        maxLength: 10,
        pattern: "",
        custom: "",
        customPrivate: false
      },
      conditional: {
        show: "",
        when: null,
        eq: ""
      }
    },
    {
      input: true,
      tableView: true,
      label: "Country",
      key: "country",
      placeholder: "Select a country",
      data: {
        json: [
          {
            name: "Afghanistan",
            code: "AF",
            $$hashKey: "object:1299"
          },
          {
            name: "Åland Islands",
            code: "AX",
            $$hashKey: "object:1300"
          },
          {
            name: "Albania",
            code: "AL",
            $$hashKey: "object:1301"
          },
          {
            name: "Algeria",
            code: "DZ",
            $$hashKey: "object:1302"
          },
          {
            name: "American Samoa",
            code: "AS",
            $$hashKey: "object:1303"
          },
          {
            name: "AndorrA",
            code: "AD",
            $$hashKey: "object:1304"
          },
          {
            name: "Angola",
            code: "AO"
          },
          {
            name: "Anguilla",
            code: "AI"
          },
          {
            name: "Antarctica",
            code: "AQ"
          },
          {
            name: "Antigua and Barbuda",
            code: "AG"
          },
          {
            name: "Argentina",
            code: "AR"
          },
          {
            name: "Armenia",
            code: "AM"
          },
          {
            name: "Aruba",
            code: "AW"
          },
          {
            name: "Australia",
            code: "AU"
          },
          {
            name: "Austria",
            code: "AT",
          },
          {
            name: "Azerbaijan",
            code: "AZ"
          },
          {
            name: "Bahamas",
            code: "BS",
          },
          {
            name: "Somalia",
            code: "SO"
          },
          {
            name: "South Africa",
            code: "ZA"
          },
          {
            name: "South Georgia and the South Sandwich Islands",
            code: "GS"
          },
          {
            name: "Spain",
            code: "ES"
          },
          {
            name: "Sri Lanka",
            code: "LK"
          },
          {
            name: "Sudan",
            code: "SD"
          },
          {
            name: "Suriname",
            code: "SR"
          },
          {
            name: "Svalbard and Jan Mayen",
            code: "SJ"
          },
          {
            name: "Swaziland",
            code: "SZ"
          },
          {
            name: "Sweden",
            code: "SE"
          },
          {
            name: "Switzerland",
            code: "CH"
          },
          {
            name: "Syrian Arab Republic",
            code: "SY"
          },
          {
            name: "Taiwan, Province of China",
            code: "TW"
          },
          {
            name: "Tajikistan",
            code: "TJ"
          },
          {
            name: "Tanzania, United Republic of",
            code: "TZ"
          },
          {
            name: "Thailand",
            code: "TH"
          },
          {
            name: "Timor-Leste",
            code: "TL"
          },
          {
            name: "Togo",
            code: "TG"
          },
          {
            name: "Tokelau",
            code: "TK"
          },
          {
            name: "Tonga",
            code: "TO"
          },
          {
            name: "Trinidad and Tobago",
            code: "TT"
          },
          {
            name: "Tunisia",
            code: "TN"
          },
          {
            name: "Turkey",
            code: "TR"
          },
          {
            name: "Turkmenistan",
            code: "TM"
          },
          {
            name: "Turks and Caicos Islands",
            code: "TC"
          },
          {
            name: "Tuvalu",
            code: "TV"
          },
          {
            name: "Uganda",
            code: "UG"
          },
          {
            name: "Ukraine",
            code: "UA"
          },
          {
            name: "United Arab Emirates",
            code: "AE"
          },
          {
            name: "United Kingdom",
            code: "GB"
          },
          {
            name: "United States",
            code: "US"
          },
          {
            name: "United States Minor Outlying Islands",
            code: "UM"
          },
          {
            name: "Uruguay",
            code: "UY"
          },
          {
            name: "Uzbekistan",
            code: "UZ"
          },
          {
            name: "Vanuatu",
            code: "VU"
          },
          {
            name: "Venezuela",
            code: "VE"
          },
          {
            name: "Viet Nam",
            code: "VN"
          },
          {
            name: "Virgin Islands, British",
            code: "VG"
          },
          {
            name: "Virgin Islands, U.S.",
            code: "VI"
          },
          {
            name: "Wallis and Futuna",
            code: "WF"
          },
          {
            name: "Western Sahara",
            code: "EH"
          },
          {
            name: "Yemen",
            code: "YE"
          },
          {
            name: "Zambia",
            code: "ZM"
          },
          {
            name: "Zimbabwe",
            code: "ZW"
          }
        ],
        url: "",
        resource: "",
        custom: "",
        headers: [
          {
            value: "",
            key: ""
          }
        ]
      },
      dataSrc: "json",
      valueProperty: "code",
      defaultValue: "",
      refreshOn: "",
      filter: "none",
      authenticate: false,
      template: "<span>{{ item.name }}</span>",
      multiple: false,
      protected: false,
      unique: false,
      persistent: true,
      hidden: false,
      clearOnHide: true,
      validate: {
        required: true
      },
      type: "select",
      $$hashKey: "object:565",
      hideLabel: false,
      labelPosition: "top",
      tags: [],
      conditional: {
        show: "",
        when: null,
        eq: ""
      },
      lockKey: true,
      limit: ""
    },
    {
      input: true,
      label: "Submit",
      tableView: false,
      key: "submit",
      size: "lg",
      leftIcon: "",
      rightIcon: "",
      block: true,
      action: "submit",
      disableOnInvalid: true,
      theme: "primary",
      type: "button"
    },
    {
      type: "me", // MeComponent
      tableView: true,
      persistent: true,
      unique: false,
      protected: false,
      defaultValue: "",
      input: true
    }
  ]
};

@Injectable()
export class FormSchemaService {
  constructor() {}

  public getFormSchema(): Observable<any> {
    return Observable.of(data).delay(1000);
  }
}

me.component.ts

import { Formio } from "formiojs/full";
import { Component, OnInit } from "@angular/core";
import {
  FormioResourceService,
  FormioResourceViewComponent,
  FormioResourceConfig
} from "angular-formio/resource";
import { FormioAppConfig } from "angular-formio";

@Component({
  template: `
  <p>Me Component</p>
  `
})
export class MeComponent extends FormioResourceViewComponent implements OnInit {
  constructor(
    public service: FormioResourceService,
    public config: FormioResourceConfig
  ) {
    super(service, config);
    console.log(service, config);
  }

  ngOnInit() {
    console.log("MeComponent --> ", this.service.resource);
  }
}

Formio.registerComponent("me", MeComponent);

Может кто-нибудь, пожалуйста, помогите мне в этом? Благодарю.

3 ответа

Компоненты, которые вы регистрируете в Formio.registerComponent не угловые компоненты, а скорее компоненты, которые должны быть получены из BaseComponent found @ https://github.com/formio/formio.js/blob/master/src/components/base/Base.js.

Из-за этого ваш код для пользовательского компонента будет выполняться вне рамок Angular, но все равно будет функционировать, когда он визуализируется с использованием Angular. Вот пример.

import { BaseComponent } from 'formiojs/src/components/base/Base';
export class CustomComponent extends BaseComponent {
  elementInfo() {
    let info = super.elementInfo();
    info.type = 'input';
    info.changeEvent = 'input';
    return info;
  }
}

Formio.registerComponent('custom', CustomComponent);
import { BaseComponent } from 'formiojs/build/components/base/Base';
import { Formio } from 'formiojs/full';

export class CustomComponent extends BaseComponent {
  rows: string;
constructor(component, options, data) {
super(component, options, data);
this.rows = "";

}
elementInfo() {
    let info = super.elementInfo();
    console.log('sddsd');
    info.type = 'input';
    info.changeEvent = 'input';

    return info;
  }
  build(){
    super.build();
    let ele = super.renderTemplate("<div id='custom'>name</div>", {});
    let element = super.getElement();
    element.appendChild(ele);
  }
}

Чтобы использовать свой пользовательский компонент в Formio, вы должны зарегистрировать свой компонент там, где он используется (используется), предпочтительно в конструкторе вашего углового компонента. Например:

constructor(    
  ) {
      Formio.registerComponent('custom', CustomComponent);
     Formio.registerComponent('question', QuestionnaireComponent);
     Formio.registerComponent('autotext', AutoTextRendererComponent);
  }
Другие вопросы по тегам