How to pass logged-in user data to embedded form

NOTE: the code below is outdated please use this version from @StevenS

If the embedded form supports passing data by url then one can use a code similar to this one to pass currently logged in user info to the form:

<script>
    let tallyUrl = 'https://tally.so/embed/urlHash?hideTitle=1&alignLeft=1';

    if(window['logged_in_user'] && window['logged_in_user']['airtable_record_id']) {
        tallyUrl = tallyUrl + '&record_id=' + window['logged_in_user']['airtable_record_id'];
    }
 
    document.write('<iframe src="' + tallyUrl + '" width="100%" height="500" frameborder="0" marginheight="0" marginwidth="0" title="My Application"></iframe>');
</script>

Please note that the above code it supposed to work within custom code block.

3 Likes

Thanks for the tips.

I notice it’s possible to get all the fields of the Airtable users (linked to Softr users) .
Exemple to get the field subName
window['logged_in_user']['subName']

Hi Jerome we expose so you can pass it as hidden parameters.

Thank you Artur for this Code.
Would it possible for you to explain how to use/implement it?
Thank you in advance!

Dear @Amaury,

You will need to add this to Custom Code block.

Let me know if you have more questions.

Hi Artur, Suzie
I want to prefill a form of Cognito Forms with the record ID ( {URL_PARAM:recordId} ) on list details block. The page will have a little form included.
I tried with the methods that you explain above, and also with an example with Jotforms and did not work for Cognito Forms.

The URL used for Cognito Forms to prefill, has this structure:
http://mysite.com/contactus?entry={“PostalCode”:“90210”,“Country”:“United States”,“RecordID”:“recXXXXXXXXX”}

For this example, the form include the field Postal Code, Country and RecordID.

It is possible some script to pass {URL_PARAM:recordId} to the form?

1 Like

@pinillo can you pls share the full code you used in your page ?

Hi Artur, thanks for your fast reply

Below an example code of the Cognito form. My idea is populate the Agent field(with {LOGGED_IN_USER:NAME}) and RecordID field ({URL_PARAM:recordId})

In Cognito forms, I can prefill the fields statically with the code below:

If the prefill is using the URL format, then use ?entry= as I share in the previous post

Thanks in advance!

Hi, can you write how it would look in the full scrip - this is my first website which I’m building, and I don’t know how to code at all, that would be really helpful. :slight_smile:

Stumbled upon this and it’s super helpful. Some additional questions for a non-everyday-coder please :blush:

  1. On the Tally.so side, how can I see / handle / process the incoming logged-in user data?
  2. I’m using custom Tally.so domains, does the code require any changes?
  3. I’m specifically looking to pass the Softr logged-in user E-MAIL address, any changes?
  4. Finally (I think lol) do I add this code to the custom code block that currently contains my Tally.so form embed code, do I replace that code with this, or add this below or above the embed code?
    Thanks again for the great assist.

Would love some answers to these questions too! Thanks in advance for the help :slight_smile:

Hi @chuchane1 at this point, I’d recommend you trying out our new conditional forms are you’ll have access to the logged in users data natively and would make for a much easier building experience.

This code doesn’t work anymore because of “document.write()” being deprecated. Here is the updated code you guys should use:

→ Don’t forget to insert your tally form id under [FORM_ID]

<script>
  let tallyUrl = 'https://tally.so/embed/[FORM_ID]?hideTitle=1&transparentBackground=1&dynamicHeight=1';

  if (window['logged_in_user'] && window['logged_in_user']['record_id']) {
    tallyUrl = tallyUrl + '&record_id=' + encodeURIComponent(window['logged_in_user']['record_id']);
  }

  // Create the iframe element
  const iframe = document.createElement('iframe');
  iframe.src = tallyUrl;
  iframe.style.width = '100%';
  iframe.style.height = '500px';
  iframe.style.border = 'none';
  iframe.style.margin = '0';
  iframe.title = 'My Application';

  // Insert the iframe into the document
  document.currentScript.parentNode.insertBefore(iframe, document.currentScript.nextSibling);
</script>
1 Like

Thanks @StevenS I updated the first post to link to your sample