Spreadsheet to HTML form
JSS Forms is a premium extension that enables you to create an HTML form directly from the spreadsheet column definitions in your JSS spreadsheet. With this tool, you can send form data to a remote server, create new spreadsheet rows, or define custom behaviour using the onbeforesave
function.
Documentation
Settings
Method |
Description |
url?: String |
The URL where the data should be sent. |
logo?: String |
The URL of the form logo. |
instructions?: String |
Text with the instructions for the user. Default: 'Please fill the form below' |
completeMessage?: String |
Text the users after submitting the form. Default: Default: 'Thank you for your time' |
columns?: Array |
Form field definitions, extracted from a valid JSS spreadsheet. |
onbeforesave?: Function |
Intercept the save to change or cancel the user action. |
onsave?: Function |
Will trigger the method after the form is submitted by the user. |
Installation
Please choose one of the following options
Using NPM
$ npm install @jspreadsheet/forms
Using a CDN
<script src="https://cdn.jsdelivr.net/npm/@jspreadsheet/forms/dist/index.min.js"></script>
Example
The following example creates an HTML form from the JSS spreadsheet and the data will be added to a spreadsheet. But, you can send this data to a server for example.
Create a Form From my Spreadsheet
Create a new row in the spreadsheet with the form data
<html>
<script src="https://jspreadsheet.com/v11/jspreadsheet.js"></script>
<link rel="stylesheet" href="https://jspreadsheet.com/v11/jspreadsheet.css" type="text/css" />
<script src="https://jsuites.net/v5/jsuites.js"></script>
<link rel="stylesheet" href="https://jsuites.net/v5/jsuites.css" type="text/css" />
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Material+Icons" />
<script src="https://cdn.jsdelivr.net/npm/@jspreadsheet/forms/dist/index.min.js"></script>
<div id="spreadsheet1"></div>
<p><input type='button' value='Create form' id="btn1"></p>
<div id="spreadsheet2"></div>
<script>
let create = function() {
let worksheet = jss[0];
jspreadsheet.forms(document.getElementById('spreadsheet2'), {
logo: 'https://jspreadsheet.com/jspreadsheet/logo.png',
columns: worksheet.options.columns,
onbeforesave: function(el, data) {
worksheet.insertRow([{ data: Object.values(data) }]);
return false;
}
});
}
jspreadsheet.setLicense('OGRlYjg3YmI2ODE3YjUwOWJlZmI3NTQ2YWZkNGQ1ODY5MGZkY2QzYWI0ZDFhNTEyN2ViYWI2YjRkNTk2MzQ2ZDc0NDMwODhhOGYxNzdiZjA5Nzg2YjM5MzM0NGYyODQzZThlNDJiMmVkZGMwOWQyOGY5ODlmN2NjMjY2Y2E1MmMsZXlKamJHbGxiblJKWkNJNklpSXNJbTVoYldVaU9pSktjM0J5WldGa2MyaGxaWFFpTENKa1lYUmxJam94TnpNMk5EY3hOalkyTENKa2IyMWhhVzRpT2xzaWFuTndjbVZoWkhOb1pXVjBMbU52YlNJc0ltTnZaR1Z6WVc1a1ltOTRMbWx2SWl3aWFuTm9aV3hzTG01bGRDSXNJbU56WWk1aGNIQWlMQ0ozWldJaUxDSnNiMk5oYkdodmMzUWlYU3dpY0d4aGJpSTZJak0wSWl3aWMyTnZjR1VpT2xzaWRqY2lMQ0oyT0NJc0luWTVJaXdpZGpFd0lpd2lkakV4SWl3aVkyaGhjblJ6SWl3aVptOXliWE1pTENKbWIzSnRkV3hoSWl3aWNHRnljMlZ5SWl3aWNtVnVaR1Z5SWl3aVkyOXRiV1Z1ZEhNaUxDSnBiWEJ2Y25SbGNpSXNJbUpoY2lJc0luWmhiR2xrWVhScGIyNXpJaXdpYzJWaGNtTm9JaXdpY0hKcGJuUWlMQ0p6YUdWbGRITWlMQ0pqYkdsbGJuUWlMQ0p6WlhKMlpYSWlMQ0p6YUdGd1pYTWlYU3dpWkdWdGJ5STZkSEoxWlgwPQ==');
jspreadsheet.setExtensions({ forms });
let jss = jspreadsheet(document.getElementById('spreadsheet1'), {
worksheets: [{
minDimensions: [ 6, 4 ],
columns: [
{
title: 'Name'
},
{
title: 'Birthday',
type: 'calendar'
},
{
title: 'Team color',
type: 'color'
},
{
title: 'Department',
type: 'dropdown',
source: ['Accounts','IT','Marketing'],
width: '150px',
},
{
title: 'Rating',
type: 'rating',
},
{
title: 'Reviewed',
type: 'checkbox',
},
]
}],
});
document.getElementById("btn1").onclick = create
</script>
</html>
import React, { useRef } from "react";
import { Spreadsheet, Worksheet, jspreadsheet } from "@jspreadsheet/react";
import forms from "@jspreadsheet/forms";
const license = 'OGRlYjg3YmI2ODE3YjUwOWJlZmI3NTQ2YWZkNGQ1ODY5MGZkY2QzYWI0ZDFhNTEyN2ViYWI2YjRkNTk2MzQ2ZDc0NDMwODhhOGYxNzdiZjA5Nzg2YjM5MzM0NGYyODQzZThlNDJiMmVkZGMwOWQyOGY5ODlmN2NjMjY2Y2E1MmMsZXlKamJHbGxiblJKWkNJNklpSXNJbTVoYldVaU9pSktjM0J5WldGa2MyaGxaWFFpTENKa1lYUmxJam94TnpNMk5EY3hOalkyTENKa2IyMWhhVzRpT2xzaWFuTndjbVZoWkhOb1pXVjBMbU52YlNJc0ltTnZaR1Z6WVc1a1ltOTRMbWx2SWl3aWFuTm9aV3hzTG01bGRDSXNJbU56WWk1aGNIQWlMQ0ozWldJaUxDSnNiMk5oYkdodmMzUWlYU3dpY0d4aGJpSTZJak0wSWl3aWMyTnZjR1VpT2xzaWRqY2lMQ0oyT0NJc0luWTVJaXdpZGpFd0lpd2lkakV4SWl3aVkyaGhjblJ6SWl3aVptOXliWE1pTENKbWIzSnRkV3hoSWl3aWNHRnljMlZ5SWl3aWNtVnVaR1Z5SWl3aVkyOXRiV1Z1ZEhNaUxDSnBiWEJ2Y25SbGNpSXNJbUpoY2lJc0luWmhiR2xrWVhScGIyNXpJaXdpYzJWaGNtTm9JaXdpY0hKcGJuUWlMQ0p6YUdWbGRITWlMQ0pqYkdsbGJuUWlMQ0p6WlhKMlpYSWlMQ0p6YUdGd1pYTWlYU3dpWkdWdGJ5STZkSEoxWlgwPQ==';
const extensions = { forms };
export default function App() {
const spreadsheet = useRef();
const form = useRef();
const columns = [
{ title: 'Name' },
{ title: 'Birthday', type: 'calendar' },
{ title: 'Team color', type: 'color' },
{ title: 'Department', type: 'dropdown', source: ['Accounts','IT','Marketing'] },
{ title: 'Rating', type: 'rating', }, { title: 'Reviewed', type: 'checkbox', }
];
const create = () => {
let worksheet = spreadsheet.current[0];
jspreadsheet.forms(form.current, {
logo: 'https://jspreadsheet.com/jspreadsheet/logo.png',
columns: worksheet.options.columns,
onbeforesave: function(el, data) {
worksheet.insertRow([{ data: Object.values(data) }]);
return false;
}
});
}
return (
<>
<Spreadsheet ref={spreadsheet} license={license} extensions={extensions}>
<Worksheet columns={columns} minDimensions={[6, 4]}/>
</Spreadsheet>
<div ref={form}></div>
<input type="button" value="Create form" onClick={() => create()} />
</>
);
}
<template>
<Spreadsheet ref="spreadsheet" :license="license" :extensions="extensions">
<Worksheet :minDimensions="[6, 4]" />
</Spreadsheet>
<div ref="form"></div>
<input type="button" value="Create form" @click="create" />
</template>
<script>
import { Spreadsheet, Worksheet, jspreadsheet } from "@jspreadsheet/vue";
import forms from "@jspreadsheet/forms";
const license = 'OGRlYjg3YmI2ODE3YjUwOWJlZmI3NTQ2YWZkNGQ1ODY5MGZkY2QzYWI0ZDFhNTEyN2ViYWI2YjRkNTk2MzQ2ZDc0NDMwODhhOGYxNzdiZjA5Nzg2YjM5MzM0NGYyODQzZThlNDJiMmVkZGMwOWQyOGY5ODlmN2NjMjY2Y2E1MmMsZXlKamJHbGxiblJKWkNJNklpSXNJbTVoYldVaU9pSktjM0J5WldGa2MyaGxaWFFpTENKa1lYUmxJam94TnpNMk5EY3hOalkyTENKa2IyMWhhVzRpT2xzaWFuTndjbVZoWkhOb1pXVjBMbU52YlNJc0ltTnZaR1Z6WVc1a1ltOTRMbWx2SWl3aWFuTm9aV3hzTG01bGRDSXNJbU56WWk1aGNIQWlMQ0ozWldJaUxDSnNiMk5oYkdodmMzUWlYU3dpY0d4aGJpSTZJak0wSWl3aWMyTnZjR1VpT2xzaWRqY2lMQ0oyT0NJc0luWTVJaXdpZGpFd0lpd2lkakV4SWl3aVkyaGhjblJ6SWl3aVptOXliWE1pTENKbWIzSnRkV3hoSWl3aWNHRnljMlZ5SWl3aWNtVnVaR1Z5SWl3aVkyOXRiV1Z1ZEhNaUxDSnBiWEJ2Y25SbGNpSXNJbUpoY2lJc0luWmhiR2xrWVhScGIyNXpJaXdpYzJWaGNtTm9JaXdpY0hKcGJuUWlMQ0p6YUdWbGRITWlMQ0pqYkdsbGJuUWlMQ0p6WlhKMlpYSWlMQ0p6YUdGd1pYTWlYU3dpWkdWdGJ5STZkSEoxWlgwPQ==';
const extensions = { forms };
export default {
components: {
Spreadsheet,
Worksheet,
},
methods: {
create() {
let worksheet = this.$refs.spreadsheet.current[0]);
jspreadsheet.forms(this.$refs.form.current, {
logo: 'https://jspreadsheet.com/jspreadsheet/logo.png',
columns: worksheet.options.columns,
onbeforesave: function(el, data) {
worksheet.insertRow([{ data: Object.values(data) }]);
return false;
}
});
}
},
data() {
const spreadsheet = ref(null);
const form = ref(null);
const columns = [
{ title: 'Name' },
{ title: 'Birthday', type: 'calendar' },
{ title: 'Team color', type: 'color' },
{ title: 'Department', type: 'dropdown', source: ['Accounts','IT','Marketing'] },
{ title: 'Rating', type: 'rating', }, { title: 'Reviewed', type: 'checkbox', }
];
return {
spreadsheet,
columns,
license,
extensions,
};
}
}
</script>
import { Component, ViewChild, ElementRef } from "@angular/core";
import jspreadsheet from "jspreadsheet";
import "jspreadsheet/dist/jspreadsheet.css"
import "jsuites/dist/jsuites.css"
import form from "@jspreadsheet/form";
import "jsuites/dist/jsuites.css";
import "jspreadsheet/dist/jspreadsheet.css";
jspreadsheet.setLicense('OGRlYjg3YmI2ODE3YjUwOWJlZmI3NTQ2YWZkNGQ1ODY5MGZkY2QzYWI0ZDFhNTEyN2ViYWI2YjRkNTk2MzQ2ZDc0NDMwODhhOGYxNzdiZjA5Nzg2YjM5MzM0NGYyODQzZThlNDJiMmVkZGMwOWQyOGY5ODlmN2NjMjY2Y2E1MmMsZXlKamJHbGxiblJKWkNJNklpSXNJbTVoYldVaU9pSktjM0J5WldGa2MyaGxaWFFpTENKa1lYUmxJam94TnpNMk5EY3hOalkyTENKa2IyMWhhVzRpT2xzaWFuTndjbVZoWkhOb1pXVjBMbU52YlNJc0ltTnZaR1Z6WVc1a1ltOTRMbWx2SWl3aWFuTm9aV3hzTG01bGRDSXNJbU56WWk1aGNIQWlMQ0ozWldJaUxDSnNiMk5oYkdodmMzUWlYU3dpY0d4aGJpSTZJak0wSWl3aWMyTnZjR1VpT2xzaWRqY2lMQ0oyT0NJc0luWTVJaXdpZGpFd0lpd2lkakV4SWl3aVkyaGhjblJ6SWl3aVptOXliWE1pTENKbWIzSnRkV3hoSWl3aWNHRnljMlZ5SWl3aWNtVnVaR1Z5SWl3aVkyOXRiV1Z1ZEhNaUxDSnBiWEJ2Y25SbGNpSXNJbUpoY2lJc0luWmhiR2xrWVhScGIyNXpJaXdpYzJWaGNtTm9JaXdpY0hKcGJuUWlMQ0p6YUdWbGRITWlMQ0pqYkdsbGJuUWlMQ0p6WlhKMlpYSWlMQ0p6YUdGd1pYTWlYU3dpWkdWdGJ5STZkSEoxWlgwPQ==');
jspreadsheet.setExtensions({ form });
@Component({
selector: "app-root",
template: `<div #spreadsheet></div>
<div #form></div>
<input type="button" value="Create form" (click)="create()" />`
})
export class AppComponent {
@ViewChild("spreadsheet") spreadsheet: ElementRef;
@ViewChild("form") spreadsheet: ElementRef;
worksheets: jspreadsheet.worksheetInstance[];
ngAfterViewInit() {
this.worksheets = jspreadsheet(this.spreadsheet.nativeElement, {
worksheets: [{
minDimensions: [ 6, 4 ],
columns: [
{
title: 'Name'
},
{
title: 'Birthday',
type: 'calendar'
},
{
title: 'Team color',
type: 'color'
},
{
title: 'Department',
type: 'dropdown',
source: ['Accounts','IT','Marketing'],
width: '150px',
},
{
title: 'Rating',
type: 'rating',
},
{
title: 'Reviewed',
type: 'checkbox',
},
]
}],
});
}
create() {
let worksheet = this.worksheets[0];
jspreadsheet.forms(this.form, {
logo: 'https://jspreadsheet.com/jspreadsheet/logo.png',
columns: worksheet.options.columns,
onbeforesave: function(el, data) {
worksheet.insertRow([{ data: Object.values(data) }]);
return false;
}
});
}
}