Creating CTA button via embed code does not track clicks
SOLVE
In our Vue.js app, we've create a component, which we pass the CTA link, and this component will create the element and load the CTA scripts, includint the hbspt.cta.load.
We can see the views in our CTA analytics but we can't see the number of clicks. Is there anythine else we have to do?
Creating CTA button via embed code does not track clicks
SOLVE
Done, fixed!
For future reference:
Hubspot provides a "temp" URL in case the script does not run, this URL will redirect the user to the final URL, but will not track the click (!?), probably due to back end limitation due to the lack of more information. Don't know.
When added to the page, the script may not be executed, that's what threw me off in the beginning.
Furthermore, the script needs the wrapping tags with the same tags and ids.
So, here's my final component, working like a charm:
Evidence (note the URL has changed to the script):
<!-- Cta button -->
<template lang="pug">
span.hs-cta-wrapper(:id="`hs-cta-wrapper-${urlComponents[6]}`")
span.hs-cta-node(:class="`hs-cta-${urlComponents[6]}`",
:id="`hs-cta-${urlComponents[6]}`")
a(:class="buttonClass",
:href="hubspotCtaHref",
:target="target",
:title="title")
i.el-icon.m-r-10(v-if="icon", :class="`el-${icon}`")
span(v-if="!$slots.default", style="margin-left: 0")
| {{ text }}
slot
</template>
<script>
export default {
name: 'HubspotCtaButton',
props: {
text: {
type: String,
default: 'Save',
},
buttonClass: {
type: String,
default: '',
},
title: {
type: String,
default: '',
},
target: {
type: String,
default: '_blank',
},
icon: {
type: String,
default: '',
},
hubspotCtaHref: {
type: String,
required: true,
default: '',
},
hubspotCtaOptions: {
type: Object,
default: () => ({}),
},
},
data() {
return {
urlComponents: this.hubspotCtaHref.split('/'),
};
},
mounted() {
// We get the params from the link (so it's easier for the user)
// The CTA link should look like:
// https://cta-redirect.hubspot.com/cta/redirect/2853558/caccc178-4b51-40e6-9b18-6f1f53281a60
// If CTA load code is already present we don't need to add the script again
if (window.hbspt && window.hbspt.cta && window.hbspt.cta.load) {
this.loadCta();
return;
}
$.getScript('https://js.hscta.net/cta/current.js', () => {
this.loadCta();
});
},
methods: {
loadCta() {
// Add Hubspot special parameters (it will end up changing the URL);
window.hbspt.cta.load(Number(this.urlComponents[5]), this.urlComponents[6], this.hubspotCtaOptions || {});
},
},
};
</script>
P.S.: Hubspot's CTA script is very intrusive in the sense it will replace all classes and text from the DOM. I haven't tested the use of icon or slots with the link (so not sure if this part of the component is working).
P.S.: It's a shame that the CTA product team, didn't want to help.
Creating CTA button via embed code does not track clicks
SOLVE
Done, fixed!
For future reference:
Hubspot provides a "temp" URL in case the script does not run, this URL will redirect the user to the final URL, but will not track the click (!?), probably due to back end limitation due to the lack of more information. Don't know.
When added to the page, the script may not be executed, that's what threw me off in the beginning.
Furthermore, the script needs the wrapping tags with the same tags and ids.
So, here's my final component, working like a charm:
Evidence (note the URL has changed to the script):
<!-- Cta button -->
<template lang="pug">
span.hs-cta-wrapper(:id="`hs-cta-wrapper-${urlComponents[6]}`")
span.hs-cta-node(:class="`hs-cta-${urlComponents[6]}`",
:id="`hs-cta-${urlComponents[6]}`")
a(:class="buttonClass",
:href="hubspotCtaHref",
:target="target",
:title="title")
i.el-icon.m-r-10(v-if="icon", :class="`el-${icon}`")
span(v-if="!$slots.default", style="margin-left: 0")
| {{ text }}
slot
</template>
<script>
export default {
name: 'HubspotCtaButton',
props: {
text: {
type: String,
default: 'Save',
},
buttonClass: {
type: String,
default: '',
},
title: {
type: String,
default: '',
},
target: {
type: String,
default: '_blank',
},
icon: {
type: String,
default: '',
},
hubspotCtaHref: {
type: String,
required: true,
default: '',
},
hubspotCtaOptions: {
type: Object,
default: () => ({}),
},
},
data() {
return {
urlComponents: this.hubspotCtaHref.split('/'),
};
},
mounted() {
// We get the params from the link (so it's easier for the user)
// The CTA link should look like:
// https://cta-redirect.hubspot.com/cta/redirect/2853558/caccc178-4b51-40e6-9b18-6f1f53281a60
// If CTA load code is already present we don't need to add the script again
if (window.hbspt && window.hbspt.cta && window.hbspt.cta.load) {
this.loadCta();
return;
}
$.getScript('https://js.hscta.net/cta/current.js', () => {
this.loadCta();
});
},
methods: {
loadCta() {
// Add Hubspot special parameters (it will end up changing the URL);
window.hbspt.cta.load(Number(this.urlComponents[5]), this.urlComponents[6], this.hubspotCtaOptions || {});
},
},
};
</script>
P.S.: Hubspot's CTA script is very intrusive in the sense it will replace all classes and text from the DOM. I haven't tested the use of icon or slots with the link (so not sure if this part of the component is working).
P.S.: It's a shame that the CTA product team, didn't want to help.
Apologies for the delayed response while I checked with the product team which owns CTAs.
Unfortunately, I won't be able to guide you any further toward your goal.
While the lack of click tracking is due at least in part to the fact that you aren't passing a click parameter and value to the click tracking domain cms2.hubspot.com/ctas/v2, I haven't learned specific implementation steps. (To your previous question, though, I found that domain by testing a CTA embedded on my own website.)
Here's the official word from the CTA team:
"At the moment, the CTA tool has no open APIs and doesn't support embed code customization, let alone custom-built CTAs. While attempting to build a CTA isn't against our terms of service, if the customer decides they wish to customize it, it's up to them to figure out and is something [our team] would be very much against as it's likely to break at some stage."
As you can see, my hands are a bit tied... I can't offer additional steps or condone building custom CTAs with Vue.js using the HubSpot scripts.
This is the request it triggered when I clicked on it in my website. Just the normal embed code. The URL is totally different than the one you showed me. I can see that when added to Hubspot emails, the URL is yet different (possibly like yours), but the embed code is this one.
So my question would be, why the embed code does not track clicks?
To be transparent, I have never heard of this being done before. Furthermore, I'm not completely certain that it's possible to fully replicate a HubSpot CTA's functionality in a custom Vue.js component.
As I understand it and as David outlines in this topic, CTA clicks are tracked through a redirect server. I believe this is what you're going for with:
While the URL above does lead to your landing page, I've noticed some key differences between your redirect's behavior and a "real" HubSpot CTA on one of my own landing pages:
Yours is a meta redirect while an embedded HubSpot CTA uses a 301 redirect.
Your redirect URL is https://cta-redirect.hubspot.com/cta/redirect/ while a true HubSpot CTA goes through https://cms2.hubspot.com/ctas/v2/public/cs/c/.
Your redirect URL contains no query parameters while mine passes the following: cta_guid, placement_guid, portal_id, canon, redirect_url, click, hsutk, utm_referrer, pageId, __hstc, __hssc, and __hsfp. (The parameter which really jumps out is click, which may be how our CTAs count clicks.)
How did you decide on using https://cta-redirect.hubspot.com/cta/redirect as the redirect URL? (As opposed to, https://cms2.hubspot.com/ctas/v2/public/cs/c/, for example.)
Again, I can't guarantee that I'll be able to help you get everything working identically to a native HubSpot CTA, but I'm happy to explore potential options!
We haven't used any redirect or any changes were made to the link. We use the link Hubspot "gave us", so I'm not sure why the redirect is 301 or if it's not supposed to be like that. Indeed, the link currently does not have the parameters. But I figured that it should work by itself right? Because these links are used in emails, with no support for Javascript.
We tried not to change anything, and load/execute the script as it would if we were embedding the script tags. That's why I think it's strange that the views work (probably the JS being executed) but the click tracking doesn't.