Skip to main content

Cognito Form: Embed script implementation

First, make sure all the UTM fields are created in Cognito Form. Each field should be seperate and Field Name should match the name you will use later in the implementation (see the image below).

Your default embed code from Cognito Form should look like this

<script src="https://services.cognitoforms.com/s/<YOUR FORM ID>"></script> 
<script>Cognito.load("forms", { id: "2"});</script>

Modify the embed code from Cognito Forms like the following. Notice that, we are adding entry fields to the Cognito.load.

<script src="https://services.cognitoforms.com/s/<YOUR FORM ID>"></script> 
<script>
setTimeout(function(){
	let all_params = HandL.getAll()
	Cognito.load("forms", { id: "4",
	entry: {
		"UTMCampaign":all_params['utm_campaign'],
		"UTMSource":all_params['utm_source'] ,
		"UTMMedium": all_params['utm_medium'],
		"UTMContent":all_params['utm_content'],
		"UTMTerm":all_params['utm_term'],
		"IP": all_params['handl_ip'],
		"Organic": all_params['organic_source_str']
	}});
}, 1000);
</script>

Here we only illustrated utm_* and handl_ip. However you can use all the other parameters very similar way. See the list of all the parameters available here What can I track with UTMSimple?

NOTE: Cognito does not support hidden field in the form out of the box. However you can make a regular text field hidden by creating a condition that never satisfies like this.