@goatlab/vue-formio
v4.1.0
Published
A vue.js renderer for form.io forms.
Downloads
7
Readme
Original library:
This library was forked from the original formio-vue library. It includes features to use Form.io and Goat Fluent
vue-formio
A Vue.js component for rendering out forms based on the Form.io platform.
Install
npm
Vue Formio
can be used on the server, or bundled for the client using an
npm-compatible packaging system such as Browserify or
webpack.
npm install @goatlab/vue-formio --save
Basic Usage
HTML inside of Vue template file:
<template>
<div id="app">
<formio src="" url="" form="" submission="" options="" v-on:submit=""></formio>
</div>
</template>
Javascript inside of Vue template file.
<script>
import { Form } from 'vue-formio';
export default {
name: 'app',
components: { formio: Form },
}
</script>
Props
src
: string
The form API source from form.io or your custom formio server.
See the Creating a form for where to set the API Path for your form.
You can also pass in the submission url as the src
and the form will render with the data populated from the submission.
url
: string
If you pass in the form and submission directly, some components such as resources, files and forms need to know the url of the form on the server. Pass it in with the url option.
form
: object
An object representing the form. Use this instead of src for custom forms.
Note: src
will override this property if used.
submission
: Object
An object representing the default data for the form.
Note: src
will override this if a submission url is entered.
APP_URL
: string
Host URL for the Form.io backend. It is use to intercept calls for the offline plugin
options
: object
An object with the formio.js options that is passed through. See Form.io Options.
Events
All events triggered from the form are available via the v-on property. See Form.io Events for all the available events.
Then on the form set <formio src="myform" v-on:submit="doSomething" />
FormBuilder
HTML inside of Vue template file:
<template>
<div id="app">
<formbuilder v-bind:form="{display: 'form'}" v-bind:options="{}" v-on:change="(schema) => console.log(schema)"></formio>
</div>
</template>
Javascript inside of Vue template file.
<script>
import { FormBuilder } from 'vue-formio';
export default {
name: 'app',
components: { FormBuilder },
}
</script>
License
Released under the MIT License.
Publish
npm run build && npm publish