Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/baggachipz/q-form-builder
Form Building using drag-and-drop. Uses Quasar Framework and Vue.
https://github.com/baggachipz/q-form-builder
Last synced: 3 months ago
JSON representation
Form Building using drag-and-drop. Uses Quasar Framework and Vue.
- Host: GitHub
- URL: https://github.com/baggachipz/q-form-builder
- Owner: baggachipz
- License: mit
- Created: 2019-02-19T19:17:42.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2023-01-06T01:41:08.000Z (about 2 years ago)
- Last Synced: 2024-09-27T05:56:05.132Z (4 months ago)
- Language: Vue
- Size: 3.62 MB
- Stars: 150
- Watchers: 14
- Forks: 39
- Open Issues: 26
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- quasar-awesome - github - form-builder.curtii.com) | Library allowing users to create drag-and-drop forms, with full rendering of components (for example, Wufoo, SurveyMonkey, etc.) | v1.12.8 | (Awesome Quasar [![Awesome](https://cdn.rawgit.com/sindresorhus/awesome/d7305f38d29fed78fa85652e3a63e154dd8e8829/media/badge.svg)](https://github.com/sindresorhus/awesome) / Tutorials)
README
# QFormBuilder
## Simple, reusable, drag-and-drop form editor (and renderer) for Quasar (v1) and Vue.js
[Live Demo Application](https://q-form-builder.curtii.com) ([Live demo source](https://github.com/baggachipz/q-form-builder-demo))![QFormBuilder usage preview](src/assets/qformbuilder.gif?raw=true "Preview")
### Want to build an application where your user can drag-and-drop form components to build a form?
Well, you're in luck. This library leverages the power of Vue and the beauty of Quasar components to present a form builder. Simply invoke this component with a v-model, and all form-building activities are reflected on the @input event. You can then use the same components to render your form at runtime. This library does not handle the saving or use of the data it generates; it's up to you as the developer to watch the model and handle the output as you need. Consequently, when rendering forms created by this builder, you can use the components and definitions provided to render an interface.
This library could be handy for applications like:
* Survey builder (aka SurveyMonkey clone)
* Registration database
* And an infinite world of possibilities....## Installation
```
npm install --save q-form-builder
```## Usage
```html```
```javascript
import { QFormBuilder } from 'q-form-builder'export default {
name: 'MyApp',
components: {
QFormBuilder
},
data: function () {
return {
myForm: []
}
}
}
```
In this example, the `myForm` data object array will be updated with form elements as they are added/modified/removed from the builder interface. You can then save that data as you see fit.## Sample Data Structure
```
{
cid: [unique guid string]
field_options: {
description: [text used in hint] (default '')
options: [array of options if a multiple choice type, like checkbox or radio]
}
field_type: [string describing the field type, e.g. 'text' or 'address']
label: [label to use on the form] (default: 'Untitled')
required: [boolean whether the field is "required"] (default: true)
}
```
The `field_options` property may be undefined or an empty object, as its contents are technically optional. Fields which require its use will fill that value. At a minimum, a field object will always have `cid`, `field_type`, `label`, and `required`. This data definition was used in order to be backward-compatible with the excellent (but no longer maintained) [FormBuilder](https://github.com/dobtco/formbuilder) library.## Advanced Usage
### Fields
To re-order or remove the fields available in QFormBuilder, the `source-fields` property can be specified on the `q-form-builder` tag as an array of objects specifying the type, icon, and label for each form element. The default list consists of (empty items produce an empty space in the sidebar):```javascript
[
{ type: 'text', icon: 'text_format', label: 'Text' },
{ type: 'paragraph', icon: 'text_fields', label: 'Paragraph' },
{ type: 'checkboxes', icon: 'check_box', label: 'Checkboxes' },
{ type: 'radio', icon: 'radio_button_checked', label: 'Mult. Choice' },
{ type: 'date', icon: 'event', label: 'Date' },
{ type: 'time', icon: 'access_time', label: 'Time' },
{ type: 'dropdown', icon: 'arrow_drop_down', label: 'Dropdown' },
{ type: 'email', icon: 'email', label: 'Email' },
{ type: 'name', icon: 'person', label: 'Name' },
{ type: 'simple_name', icon: 'person_outline', label: 'Simple Name' },
{ type: 'address', icon: 'home', label: 'Address' },
{ type: 'phone', icon: 'phone', label: 'Phone' },
{ type: 'file', icon: 'cloud_upload', label: 'File Upload' },
{ type: 'payment', icon: 'payment', label: 'Payment' },
{ type: 'terms', icon: 'ballot', label: 'Terms' },
{ type: '' },
{ type: '' },
{ type: '' },
{ type: 'section_break', icon: 'view_agenda', label: 'Section Break' },
{ type: 'page_break', icon: 'call_to_action', label: 'Page Break' }
]
```### Field Source Position
By default, the source fields appear on the left, with the form construction area on the right. To set the source fields on the right, the setting `nav-position` can be set to `right` (default is `left`).### Advanced Usage Example
To only include Email and Phone field objects:
```html
```
```javascript
import QFormBuilder from 'q-form-builder'export default {
name: 'MyApp',
components: {
QFormBuilder
},
data: function () {
return {
myForm: [],
mySourceFields: [
{ type: 'email', icon: 'email', label: 'Email' },
{ type: 'phone', icon: 'phone', label: 'Phone' }
]
}
}
}
```## Development and Example Application
To run the example application, clone the project from [https://github.com/baggachipz/q-form-builder](https://github.com/baggachipz/q-form-builder).### Enter the project directory, install npm dependencies, and run a local server
```
cd q-form-builder
npm install
npm run serve
```This example allows you to add form components and logs the full v-model to the debug console with every change.
## Development Roadmap
* ~~Additional field type(s): Terms & Conditions~~
* ~~Add form rendering example to Sample Application~~
* Ability to load and use custom field types