To explain more, we have created an email preferences form (embedded on a Marketo landing page) wherein each selection uses a boolean field:
Fields on existing member record:
Fields as selections on Marketo form/landing page:
I've scoured through Sandy's blogs on forms on https://blog.teknkl.com/, but did not come across a specific solution for my situ.
Is it possible to show each of the options above only if the corresponding field on an individual member's record is unchecked/false? And/or can the option be shown as checked if it is checked/true on the member's record?
Thank you,
LK
Have you checked if form pre-fill works on any other field? I'm asking as there was an issue which affected the Ashburn, London and San Jose data centers a couple weeks ago. It might be fixed by now, but you should update your form and drag it back in onto your landing page.
Thank you Michael! It was actually a caching issue.
Appreciate your input!
LK
Cookie conflicts that interfere with the pre-fill function are very common. Opening your email links in an incognito window or clearing your cache are always good ideas. 🙂
Regarding the JS: It needs to go on the page, usually just above to the closing </body>-tag. JS can't be put on forms AFAIK. That custom area only holds CSS.
We use a script like this e.g.
    <script>
setTimeout(() => {
  const check = [
    document.getElementById("checkbox1"),
    document.getElementById("checkbox2"),
  ];
  document
    .getElementById("Unsubscribed")
    .addEventListener("change", (ele) => {
      if (ele.target.value === "true" || ele.target.value === "1") {
        check.forEach((ele) => {
          ele.checked = false;
        });
      }
    });
}, 1000);
    </script>
All subsequent data value changes should rather go into a Smart Campaign IMHO. The script only handles the customer facing checkbox behavior.
Thank you Michael! It was actually a caching issue.
A cookie issue perhaps. Caching shouldn’t matter here, that would be very bad.
From what I can understand, you need the form pre-fill on your page. Based on the data of the cookied person record, you can either show/hide fields or display the fields with the data prefilled if the person record already has data for that field in the Marketo. Check out Sandy’s form pre-fill solution here.
I think you should prefill and show all the fields instead of hiding the ones that have a True value, as if you do so, the person once opted in wouldn’t be able to opt out from the individual categories via this page (unless of course if they clear their cookies or visit from a different browser or system).
Hi @Darshil_Shah1 ,
Thanks so much for your response!
I know that there is a Form Prefill setting on Marketo landing pages (see below), but are you saying that I would need to implement the instructions Sandy provided in his blog--that just enabling the Form Prefill option isn't enough?
Important to note too is that, unlike the first prerequisite in Sandy's blog, we will not be using an external site so there's no need to enable prefill on an external site. We just want to be able to update the form fields on the Marketo landing page itself based on the data on a customer record in Marketo.
Thanks again,
LK
Hi @Guitarrista82,
The native form pre fill only works if the lead lands on the landing page by clicking a tracked link from an e-mail, check this post:
https://nation.marketo.com/t5/knowledgebase/form-pre-fill-feature-upgrade/ta-p/251652
Sandy’s solution helps getting around this and with it the forms prefill as long as the person is cookied (i.e., munchkin tracking cookie is associated with a known person record in Marketo).
Hi @Darshil_Shah1,
Okay, I've run through the process of sending myself a live email containing the link to the landing page with the email subscription options form.
I enabled the settings below on the link:
I sent myself the email via a live campaign (not a test).
In Gmail, when I hover over the link to the landing page, the Marketo tracking token does appear, as shown below:
However, when I click on the link, even in incognito mode, the fields below do not appear checked, even though they are checked on the account to which I sent the email:
Results on form on landing page:
Corresponding boolean fields on my account record in Marketo:
Any ideas why the fields are not appearing prefilled on the form even though they're checked on my record?
Not sure if this would help, but when I did an inspect element on the landing page, I see these errors:
Thanks,
LK
Do you have any custom JS on your landing page? When you opened the tracked link from an email, did you see the mkt_tok query parameter added at the end of the Marketo LP URL?
Hi @Darshil_Shah1,
Actually, the issue was I had to clear the cache, then the prefill appeared.
However, a new issue has come up where, let's say someone just checks all the boxes to subscribe to the emails, but doesn't uncheck the unsubscribe box. This affects our automation processes that send API calls to an outside website that updates the contacts' subscription statuses.
It would be helpful if, when someone checks any of the email subscription boxes, the unsubscribe box was automatically unchecked. Or if they checked "unsubscribe", the email boxes would be automatically unchecked.
I saw a few discussions in the Community that provided javascript to make this happen, but I'm not sure which ones would actually work.
For reference, here's one that I thought might work (after replacing the values with our values):
<script>
    //Written by Diederik Martens (C) 2014
    MktoForms2.whenReady(function (form){
        //check for unsubscribe at any change
        form.onSubmit(function(){
            //get the form field values
            var vals = form.vals();
            //if all unchecked > unsubscribe
            if(vals.ePCNews == "No" && vals.ePCEvents == "No" && vals.ePCContent == "No" && vals.ePCLogistics == "No" && vals.ePCProduction == "No" && vals.ePCWorkforce == "No" && vals.ePCSCPO == "No" && vals.ePCSOP == "No") {
                form.vals({"Unsubscribed":"true"});
                form.vals({"Email_Opt_in__c":"false"});    
            } else {
            //something (type or topic) is still checked so we keep opt-in
                //any of the 3 types is still checked
                if(vals.ePCNews == "Yes" || vals.ePCEvents == "Yes" || vals.ePCContent == "Yes") {
                    //check if any topic is also check
                    if(vals.ePCLogistics == "Yes" || vals.ePCProduction == "Yes" || vals.ePCWorkforce == "Yes" || vals.ePCSCPO == "Yes" || vals.ePCSOP == "Yes") {
                        //at least 1 topic is checked so don't interfere. but do record optin
                        form.vals({"Unsubscribed":"false"});
                        form.vals({"Email_Opt_in__c":"true"});    
                    } else {
                        //none of the topics are checked, whilist at least 1 type is checked. so check all topics by default
                        form.vals({"Unsubscribed":"false"});
                        form.vals({"Email_Opt_in__c":"true"});    
                        form.vals({"ePCLogistics":"Yes"});
                        form.vals({"ePCProduction":"Yes"});
                        form.vals({"ePCSCPO":"Yes"});
                        form.vals({"ePCSOP":"Yes"});
                        form.vals({"ePCWorkforce":"Yes"});                        
                    }
                }
                //none of the 3 types are checked
                else {
                    //check if any topic is checked.
                    if(vals.ePCLogistics == "Yes" || vals.ePCProduction == "Yes" || vals.ePCWorkforce == "Yes" || vals.ePCSCPO == "Yes" || vals.ePCSOP == "Yes") {
                        //at least 1 topic is checked, whilist no type is checked, lets keep the person opt-in, but which type to check? check all.
                        form.vals({"Unsubscribed":"false"});
                        form.vals({"Email_Opt_in__c":"true"});    
                        form.vals({"ePCNews":"Yes"});
                        form.vals({"ePCEvents":"Yes"});
                        form.vals({"ePCContent":"Yes"});
                    } else {
                        //no topics are checked, and no types are checked, so opt-out
                        form.vals({"Unsubscribed":"true"});
                        form.vals({"Email_Opt_in__c":"false"});    
                        form.vals({"ePCNews":"No"});
                        form.vals({"ePCEvents":"No"});
                        form.vals({"ePCContent":"No"});
                        form.vals({"ePCLogistics":"No"});
                        form.vals({"ePCProduction":"No"});
                        form.vals({"ePCSCPO":"No"});
                        form.vals({"ePCSOP":"No"});
                        form.vals({"ePCWorkforce":"No"});
                    }
                }
            }        
            var valszz = form.vals();
            //alert("Submitted values: " + JSON.stringify(valszz));
        });
    });
</script>
Darshil or @SanfordWhiteman, is there a specific javascript we can use to automate this directly on the landing page? And would this JS need to be applied to the landing page or in the form's CSS?
Thank you,
LK
Okay, understood...
Please see my additional comment below:
Important to note too is that, unlike the first prerequisite in Sandy's blog, we will not be using an external site so there's no need to enable prefill on an external site. We just want to be able to update the form fields on the Marketo landing page itself based on the data on a customer record in Marketo.
So then would Sandy's form prefill hack be needed in my case? It sounds like I just need to test out visiting the landing page directly from an email, in this case?
Thanks,
LK
Gotcha! The native form prefill does work on clicking a tracked email link to the Marketo LP.
