Plain JS Embedding
data:image/s3,"s3://crabby-images/d7c32/d7c32c0fb95774b366c81639938fd44bbb0c3573" alt=""
data:image/s3,"s3://crabby-images/b21ac/b21ac2547b1068c59f0d9296bdf1bf662176c741" alt=""
data:image/s3,"s3://crabby-images/64141/641410970bf8a73069cae595f3dd4b3e4e00a17e" alt=""
data:image/s3,"s3://crabby-images/c3985/c39858ec4027dd26558f1986bf6f3bdc1f99db92" alt=""
data:image/s3,"s3://crabby-images/b42d8/b42d81140cfc56c87583b93290bacd6a03584384" alt=""
data:image/s3,"s3://crabby-images/3c686/3c6861eac74c8c66ca6fb51ef164892a0394203c" alt=""
data:image/s3,"s3://crabby-images/0cd85/0cd856c96a5c9e35d08a1e0d8dd05aad763d532a" alt=""
Formally supports non-React integration through a plain JavaScript API.
Prerequisites
- A published form made in the GetFormally.com form builder
Embedding
GetFormally.com will provide a snippet of HTML for you to use.
Generally speaking the HTML will resemble this...
<div data-formally="your-form-id"></div>
<script src="https://form-data.getformally.com/formally.min.js"></script>
<link href="https://form-data.getformally.com/styles.min.css" />
SDK
The Plain JS SDK is under development. Feedback to formally@getformally.com is appreciated.
Licence
Provide a data-formallylicence
attribute with the licence string. Ie,
<div data-formally="your-form-id" data-formallylicence="YOUR_LICENCE"></div>
<script src="https://form-data.getformally.com/formally.min.js"></script>
<link href="https://form-data.getformally.com/styles.min.css" />
Default values
Default values can be provided as JSON inside the <div>
tag as,
<div data-formally="your-form-id" data-formallylicence="YOUR_LICENCE">
<script type="application/json" data-formallydefaultvalues>
{
"field-id": "default value"
}
</script>
</div>
<script src="https://form-data.getformally.com/formally.min.js"></script>
<link href="https://form-data.getformally.com/styles.min.css" />
onSubmit
and onSubmitComplete
handler
import { WindowAPI as FormallyWindowAPI } from 'formally';
const formId = 'your-form-id';
((window as any)[`formally-${formId}`] as FormallyWindowAPI) = {
onSubmit: (props) => {
console.log(props);
alert('onSubmit handler');
return {
type: 'success',
localisedMessage: '',
};
},
onSubmitComplete: (submitResponse, props) => {
console.log(submitResponse, props);
alert('onSubmitComplete handler');
},
};
Storing unsubmitted answers in storage
Formally can save unsubmitted answers in browser storage (localStorage
).
Answers will be saved automatically if you're using "data-formally" however if you're using JSON then you can provide a key.
Provide a data-formallycachekey
attribute with a value that is unique to your form (ie, data-formallycachekey="dog-form"
). This will be used for a localStorage
key.