react-talend-forms

0.111.0 • Public • Published

react-talend-forms

Build Status

Introduction

This library is designed to be used on top of react-jsonschema-form, a React component for building Web forms from JSONSchema.

In addition of Mozilla lib, this wrapper uses react-bootstrap to not have to maintain Bootstrap markup.

Installation

Run npm install --save react-talend-forms.

Usage

The forms can be used like any other React components. You'll have to pass it a JSONSchema and a onSubmit callback as a minimum to handle forms rendering and get the data back.

import Form from 'react-talend-forms';
 
class MyForm extends React.Component {
 
    onSubmit(formData) {
        console.log(formData);
    }
 
    onCancel() {
        console.log('Cancelled');
    }
 
    render() {
        const actions = [
            { style: 'link', onClick: this.onCancel, type: 'button', label: 'CANCEL' },
            { style: 'primary', type: 'submit', label: 'VALIDATE' },
        ];
        return (
            <Form data={this.props.data} actions={actions} onSubmit={this.onSubmit} />
        );
    }
}

Here is the archetype of the data property required to render the form:

{
    "jsonSchema": {},
    "uiSchema": {},
    "properties": {}
}

Actions

Forms now render a react-talend-components Action component for each action given to it. Each action accept the following properties :

property propType required default doc
iconPosition other no -
icon string no -
hideLabel bool no -
disabled bool no {false}
style string no "default" equivalent to action bsStyle props
iconTransform string no -
id string no -
inProgress bool no {false}
label string yes -
link bool no -
model object no -
name string no - render a name button html property
onClick func yes - execute the callback with formData, formId, propertyName, propertyValue as parameters
tooltip bool no -
tooltipPlacement other no "top"
type 'submit'|'button' no - by default render a button without submit type

Handlers

If uiSchema has some triggers like

{
  "jsonSchema": {
    "id": "ListExample",
    "type": "object",
    "properties": {
      "propertyName": {
        "type": "string",
        "enum": [
          "option 0",
          "option 1",
          "option 2"
        ]
      }
    }
  },
  "uiSchema": {
    "propertyName": {
      "ui:trigger": [ "after" ]
    }
  },
  "properties": {}
}

Then onChange will be triggered when propertyName field value has changed.

import Form from 'react-talend-forms';
 
class MyForm extends React.Component {
 
    onChange(formData, formId, propertyName, propertyValue) {
        console.log(formData, formId, propertyName, propertyValue);
    }
 
    onSubmit(formData) {
        console.log(formData);
    }
 
    render() {
        return (
            <Form
                data={this.props.data}
                onChange={this.onChange}
                onSubmit={this.onSubmit}
            />
        );
    }
}

PropTypes

The data and actions PropTypes are exported for easy reuse. You can use them by importing the DataPropTypes and ActionsPropTypes functions.

import Form, { DataPropTypes, ActionsPropTypes } from 'react-talend-forms'

LICENSE

Copyright (c) 2006-2016 Talend

Licensed under the Apache V2 License

Dependencies (6)

Dev Dependencies (52)

Package Sidebar

Install

npm i react-talend-forms

Weekly Downloads

19

Version

0.111.0

License

Apache-2.0

Last publish

Collaborators

  • frassinier
  • glorieux
  • jmfrancois
  • jsomsanith
  • sromain