CMS Development

FViana
Mitglied

hubspot cookie callback

lösung

Hey!

 

I need help, we have a website with the integration of the hubspot in the contact forms and in the widget of our bot.

 

However, our widget is loaded before the hubspot by the wordpress footer script. Is there any way to place a callback on the main hubspot script? so that our widget is loaded with the value of the hubspotutk variable?

 

We are currently trying to get the cookie like this, but our script must 'wait' for the hubspot, as the value does not exist, the variable is empty.


function getCookieGeneric(cname) {
    var name = cname + "=";
    var decodedCookie = decodeURIComponent(document.cookie);
    var ca = decodedCookie.split(';');
    for (var i = 0; i < ca.length; i++) {
        var c = ca[i];
        while (c.charAt(0) == ' ') {
            c = c.substring(1);
        }
        if (c.indexOf(name) == 0) {
            return c.substring(name.length, c.length);
        }
    }
    return "";
}

var prechat_inputs = {};
prechat_inputs["hubspotutk"] = getCookieGeneric('hubspotutk');

var chatbotKey = 'someKEYHere';

(function(d, r, o, z, a, k, t) {
        a = d.getElementsByTagName('head')[0];
        k = d.createElement('script');
        k.async = 1;
        t = (Math.floor(Math.random() * 1000000) + 1);
        k.src=r + '/' + o + '/droz.js?i=' + z + '&u=' + r + '&v=' + t;
        a.appendChild(k);
    })(document, 'https://chat-app.meudroz.com', 'v1', chatbotKey);

 

 

0 Upvotes
1 Akzeptierte Lösung
FViana
Lösung
Mitglied

hubspot cookie callback

lösung

I found a solution, but I haven't tested it yet, I believe there is an easier way but I haven't found it anywhere.

It can be considered a workaround.

 

If you do not have the cookie (page was loaded for the first time) ... run this:

 

		var checkCookie = function() {

		var lastCookies = document.cookie.split( ';' ).map( function( x ) { return x.trim().split( /(=)/ ); } ).reduce( function( a, b ) { 
				a[ b[ 0 ] ] = a[ b[ 0 ] ] ? a[ b[ 0 ] ] + ', ' + b.slice( 2 ).join( '' ) :  
				b.slice( 2 ).join( '' ); return a; }, {} );


		return function() {

			var currentCookies =  document.cookie.split( ';' ).map( function( x ) { return x.trim().split( /(=)/ ); } ).reduce( function( a, b ) { 
				a[ b[ 0 ] ] = a[ b[ 0 ] ] ? a[ b[ 0 ] ] + ', ' + b.slice( 2 ).join( '' ) :  
				b.slice( 2 ).join( '' ); return a; }, {} );


			for(cookie in currentCookies) {
				if  ( currentCookies[cookie] != lastCookies[cookie] ) {
					console.log("--------")
					console.log(cookie+"="+lastCookies[cookie])
					console.log(cookie+"="+currentCookies[cookie])
                                        // get value from hubspotutk !!
                                        // call my widget
				}

			}
			lastCookies = currentCookies;

		};
		}();

		window.setInterval(checkCookie, 100);

 

if you have the cookie, verified by the getCookieGeneric function (which I posted up there) take the value and call our widget.

 

This is not ideal, more is something, if anyone has any better ideas please post here below

 

 

Lösung in ursprünglichem Beitrag anzeigen

4 Antworten
FViana
Mitglied

hubspot cookie callback

lösung

@dennisedsonis this a good solution? 🤔

0 Upvotes
FViana
Lösung
Mitglied

hubspot cookie callback

lösung

I found a solution, but I haven't tested it yet, I believe there is an easier way but I haven't found it anywhere.

It can be considered a workaround.

 

If you do not have the cookie (page was loaded for the first time) ... run this:

 

		var checkCookie = function() {

		var lastCookies = document.cookie.split( ';' ).map( function( x ) { return x.trim().split( /(=)/ ); } ).reduce( function( a, b ) { 
				a[ b[ 0 ] ] = a[ b[ 0 ] ] ? a[ b[ 0 ] ] + ', ' + b.slice( 2 ).join( '' ) :  
				b.slice( 2 ).join( '' ); return a; }, {} );


		return function() {

			var currentCookies =  document.cookie.split( ';' ).map( function( x ) { return x.trim().split( /(=)/ ); } ).reduce( function( a, b ) { 
				a[ b[ 0 ] ] = a[ b[ 0 ] ] ? a[ b[ 0 ] ] + ', ' + b.slice( 2 ).join( '' ) :  
				b.slice( 2 ).join( '' ); return a; }, {} );


			for(cookie in currentCookies) {
				if  ( currentCookies[cookie] != lastCookies[cookie] ) {
					console.log("--------")
					console.log(cookie+"="+lastCookies[cookie])
					console.log(cookie+"="+currentCookies[cookie])
                                        // get value from hubspotutk !!
                                        // call my widget
				}

			}
			lastCookies = currentCookies;

		};
		}();

		window.setInterval(checkCookie, 100);

 

if you have the cookie, verified by the getCookieGeneric function (which I posted up there) take the value and call our widget.

 

This is not ideal, more is something, if anyone has any better ideas please post here below

 

 

dennisedson
HubSpot-Produktteam
HubSpot-Produktteam

hubspot cookie callback

lösung

@piersg , @Kevin-C  how would you handle this?

0 Upvotes
FViana
Mitglied

hubspot cookie callback

lösung

Anyone can help me?

 

Thanks.

0 Upvotes