Custom Analytics
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=""
Start of documentation contentUse of
Formally includes custom analytics handlers, however this is disabled by default for privacy reasons.
Use of onAnalytics
By writing a small adaptor you can wire up Formally to your own Analytics API. This does not allow you to track additional features, just to dispatch them to a different service. This may allow greater data sovereignty.
You can override the default analytics handler
import { Formally } from 'formally';
<Formally
onAnalytics={({ eventType, sessionId, formId, formVersionId }) => {
// Send anonymous statistics to your own analytics service
//
// eventType is either "form-focus", "page-change", or "form-submit".
//
// sessionId is a string id randomly generated
// * per browser tab, and
// * per form, and
// * per page load.
// The sessionId is not persisted (in any storage/cookies etc) so
// every page load will regenerate the sessionId.
// The sessionId is just derived from math.random() and it's not
// cryptographically seeded by any user identifiable details.
// The purpose of the sessionId is to associate multiple analytics
// events with a single user session of a form.
if (eventType === 'form-submit') {
// call your analytics service when the form submits
}
// nothing needs to be returned from this function
}}
/>;